{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "6d070d4b",
   "metadata": {},
   "source": [
    "# Copyright Notice\n",
    "Copyright 2025 Anonymous Authors\n",
    "\n",
    "Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:\n",
    "\n",
    "The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.\n",
    "\n",
    "THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "481ece34",
   "metadata": {},
   "source": [
    "# ✅ Quick Start for Evaluating ARLs and ADDs of Changeoint Detectors\n",
    "\n",
    "## Important Note\n",
    "- All sequences are supposed to contain either (1) exclusively pre-change frames or (2) pre-change frames followed by post-change frames. We do not support multiple changepoint detection nor changepoint isolation.\n",
    "- You need `ls_changepoints` (changepoint indices: 0-based), `ls_durations` (sequence lengths: 1-based), and `ls_predictions` (detection indices: 0-based) to compute the KME-ARL and KME-ADD.\n",
    "  - Changepoints must set to inf (float(\"inf\") or np.inf) if a sequence does not have a changepoint.\n",
    "  - Prediction (detection point) must set to -1 if no changepoint was detected.\n",
    "- We also add some comments in the following for users."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc5e5f47",
   "metadata": {},
   "source": [
    "# 1. Generate Sequential Dataset and Detect Changepoints"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "09f21bfe",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated 10000 sequences with variable lengths.\n",
      "Average duration of sequences: 546.57\n",
      "Average changepoint position: inf.\n",
      "Average predicted changepoint position: 182.31.\n",
      "Durations: [877, 400, 1000, 368, 328, 304, 810, 374, 858, 175, 558, 980, 458, 515, 517, 457, 853, 679, 739, 354, 404, 677, 351, 644, 297, 834, 521, 576, 222, 997, 219, 816, 574, 602, 452, 573, 640, 372, 627, 622, 238, 470, 507, 662, 474, 669, 990, 751, 459, 790, 416, 413, 345, 703, 337, 356, 797, 862, 980, 136, 947, 260, 261, 580, 915, 920, 214, 550, 775, 763, 322, 539, 844, 686, 136, 334, 157, 612, 364, 394, 703, 724, 462, 863, 590, 174, 222, 997, 369, 389, 860, 664, 962, 997, 760, 409, 132, 774, 566, 393, 235, 299, 239, 312, 882, 411, 234, 129, 135, 619, 353, 996, 885, 924, 912, 945, 125, 297, 178, 514, 286, 342, 498, 206, 695, 876, 657, 371, 753, 482, 934, 795, 195, 564, 661, 974, 221, 258, 319, 130, 887, 432, 303, 143, 886, 944, 635, 733, 442, 964, 835, 192, 976, 126, 131, 377, 787, 231, 379, 414, 801, 688, 673, 876, 148, 763, 867, 571, 516, 519, 120, 366, 831, 362, 572, 772, 819, 364, 601, 882, 786, 376, 269, 529, 455, 689, 305, 714, 118, 362, 976, 318, 886, 264, 105, 323, 610, 300, 645, 442, 674, 773, 398, 898, 594, 664, 900, 504, 159, 847, 628, 932, 102, 580, 580, 825, 733, 248, 722, 110, 830, 214, 564, 996, 787, 216, 558, 157, 381, 480, 324, 960, 294, 847, 686, 742, 856, 176, 930, 984, 527, 818, 564, 319, 341, 200, 506, 766, 994, 309, 138, 102, 983, 539, 720, 103, 294, 387, 512, 373, 770, 518, 421, 615, 854, 610, 447, 640, 800, 431, 928, 352, 464, 757, 159, 462, 928, 987, 895, 164, 104, 187, 417, 564, 271, 477, 674, 985, 455, 936, 551, 927, 420, 310, 774, 840, 385, 837, 981, 161, 984, 973, 616, 603, 390, 437, 307, 930, 905, 890, 915, 109, 733, 176, 149, 920, 776, 382, 117, 207, 621, 353, 556, 267, 775, 860, 393, 462, 852, 714, 302, 289, 514, 376, 220, 149, 143, 292, 420, 476, 847, 155, 400, 461, 891, 595, 692, 817, 270, 652, 696, 160, 900, 189, 567, 865, 172, 995, 514, 454, 273, 485, 689, 434, 316, 846, 944, 564, 132, 905, 420, 214, 215, 222, 184, 255, 944, 452, 353, 116, 309, 917, 511, 199, 776, 616, 929, 693, 295, 777, 341, 231, 367, 777, 505, 228, 403, 333, 175, 226, 670, 407, 815, 310, 371, 625, 856, 229, 907, 230, 602, 557, 796, 746, 892, 560, 699, 139, 729, 190, 330, 634, 619, 489, 235, 559, 490, 636, 551, 624, 782, 414, 950, 753, 948, 629, 420, 796, 430, 977, 259, 327, 828, 840, 852, 316, 412, 928, 517, 427, 774, 648, 194, 948, 297, 117, 712, 943, 218, 873, 771, 529, 296, 902, 378, 705, 873, 649, 773, 897, 989, 924, 736, 216, 575, 757, 178, 915, 404, 567, 861, 928, 277, 872, 319, 303, 424, 489, 168, 117, 708, 499, 947, 941, 768, 456, 518, 168, 699, 984, 710, 439, 848, 762, 493, 451, 388, 534, 311, 471, 666, 216, 692, 889, 454, 215, 110, 754, 897, 963, 790, 173, 975, 850, 429, 463, 265, 487, 119, 652, 865, 319, 365, 237, 783, 993, 746, 846, 827, 654, 230, 482, 830, 747, 420, 627, 368, 703, 450, 430, 896, 930, 692, 741, 928, 882, 197, 465, 189, 407, 425, 614, 579, 360, 496, 650, 897, 528, 527, 716, 234, 387, 657, 493, 921, 456, 827, 153, 257, 185, 867, 209, 531, 289, 995, 676, 195, 727, 560, 430, 996, 783, 669, 985, 846, 423, 843, 451, 380, 926, 342, 945, 213, 613, 973, 637, 809, 502, 466, 399, 526, 754, 657, 939, 238, 856, 781, 328, 795, 408, 185, 632, 310, 147, 733, 161, 808, 450, 570, 773, 218, 628, 170, 420, 876, 329, 470, 200, 514, 104, 665, 392, 955, 707, 974, 624, 873, 392, 481, 456, 482, 334, 410, 828, 470, 318, 244, 450, 407, 791, 268, 114, 782, 236, 720, 933, 812, 684, 287, 276, 700, 799, 954, 422, 830, 710, 636, 648, 195, 974, 683, 919, 967, 477, 693, 862, 185, 377, 237, 750, 395, 419, 783, 932, 834, 563, 501, 211, 616, 851, 180, 247, 738, 131, 508, 910, 967, 509, 540, 359, 444, 826, 687, 705, 646, 866, 776, 612, 531, 125, 718, 650, 716, 716, 690, 348, 114, 823, 207, 218, 561, 108, 264, 658, 244, 873, 551, 679, 205, 992, 557, 658, 192, 954, 355, 215, 698, 204, 126, 626, 577, 469, 832, 245, 894, 864, 495, 560, 202, 499, 754, 852, 746, 667, 705, 653, 520, 764, 490, 865, 940, 716, 523, 616, 931, 485, 643, 539, 735, 113, 215, 536, 908, 862, 145, 620, 212, 738, 829, 689, 189, 105, 140, 580, 430, 541, 106, 814, 921, 987, 784, 448, 851, 354, 450, 615, 912, 659, 614, 509, 183, 207, 868, 122, 979, 658, 1000, 139, 183, 393, 558, 295, 840, 569, 859, 295, 480, 508, 506, 919, 266, 695, 247, 936, 850, 742, 210, 914, 411, 807, 779, 543, 732, 139, 431, 128, 971, 192, 125, 169, 260, 489, 399, 466, 851, 166, 213, 605, 709, 900, 764, 194, 301, 355, 984, 379, 279, 174, 311, 655, 347, 437, 376, 467, 798, 462, 581, 331, 612, 350, 258, 873, 358, 173, 902, 358, 463, 328, 159, 563, 725, 605, 643, 581, 560, 487, 885, 369, 261, 921, 637, 587, 760, 838, 965, 160, 220, 619, 436, 998, 849, 992, 940, 202, 643, 615, 864, 797, 913, 484, 867, 555, 452, 775, 381, 751, 696, 630, 672, 130, 371, 818, 187, 446, 145, 937, 553, 354, 133, 424, 949, 735, 398, 880, 835, 748, 963, 814, 395, 579, 328, 648, 966, 688, 726, 622, 515, 659, 129, 400, 377, 579, 806, 122, 990, 711, 268, 140, 914, 614, 767, 273, 286, 919, 330, 892, 588, 332, 880, 978, 450, 210, 196, 586, 829, 649, 598, 598, 398, 774, 443, 564, 378, 932, 746, 197, 586, 273, 270, 173, 736, 767, 392, 115, 705, 697, 913, 950, 575, 408, 283, 315, 233, 969, 500, 929, 429, 776, 870, 789, 582, 975, 849, 112, 340, 371, 968, 365, 520, 967, 223, 244, 549, 400, 740, 486, 668, 675, 833, 505, 299, 674, 169, 158, 439, 467, 785, 628, 523, 615, 118, 243, 339, 390, 941, 909, 627, 157, 517, 629, 821, 963, 736, 481, 982, 864, 299, 756, 826, 719, 908, 742, 789, 974, 193, 927, 971, 288, 821, 387, 746, 193, 976, 759, 215, 669, 136, 168, 817, 111, 163, 539, 957, 545, 736, 566, 715, 943, 596, 122, 553, 471, 469, 413, 615, 114, 432, 762, 359, 243, 697, 875, 763, 796, 892, 665, 333, 201, 488, 873, 333, 421, 397, 875, 108, 356, 236, 237, 338, 452, 512, 825, 491, 570, 597, 486, 600, 986, 188, 384, 368, 981, 548, 476, 974, 802, 740, 694, 506, 514, 559, 854, 320, 506, 393, 147, 511, 598, 268, 248, 844, 227, 857, 502, 419, 356, 337, 251, 554, 947, 649, 883, 340, 819, 476, 539, 123, 868, 132, 916, 513, 138, 406, 219, 506, 249, 819, 424, 591, 916, 300, 570, 423, 751, 130, 863, 891, 159, 150, 616, 969, 999, 321, 685, 395, 500, 295, 720, 443, 588, 389, 499, 797, 417, 874, 272, 392, 517, 828, 358, 354, 369, 606, 893, 523, 111, 691, 934, 200, 445, 154, 319, 890, 600, 967, 947, 776, 359, 340, 471, 414, 862, 371, 632, 213, 983, 725, 286, 785, 579, 601, 964, 491, 520, 556, 419, 647, 431, 486, 946, 619, 241, 260, 522, 498, 155, 353, 852, 135, 618, 273, 818, 992, 433, 428, 406, 275, 958, 494, 256, 778, 879, 812, 792, 721, 716, 208, 311, 143, 499, 748, 442, 168, 765, 365, 557, 596, 755, 268, 847, 614, 292, 279, 710, 917, 643, 514, 938, 987, 737, 865, 599, 868, 668, 675, 867, 380, 896, 898, 747, 351, 533, 240, 795, 249, 629, 980, 993, 130, 713, 161, 528, 536, 287, 950, 219, 356, 149, 659, 128, 709, 731, 294, 924, 660, 744, 999, 920, 482, 670, 290, 233, 155, 750, 645, 577, 233, 557, 695, 690, 796, 325, 645, 922, 542, 907, 154, 791, 483, 775, 181, 239, 430, 182, 590, 415, 681, 327, 663, 560, 303, 375, 940, 383, 956, 808, 398, 118, 606, 988, 127, 966, 693, 226, 961, 889, 403, 931, 583, 938, 742, 870, 293, 595, 990, 330, 769, 163, 358, 205, 521, 813, 290, 867, 826, 1000, 477, 976, 604, 224, 816, 137, 747, 500, 932, 345, 858, 993, 544, 622, 893, 386, 460, 152, 880, 972, 115, 387, 459, 294, 758, 473, 486, 387, 176, 189, 769, 1000, 984, 860, 785, 785, 333, 171, 322, 741, 106, 253, 783, 960, 581, 112, 784, 253, 619, 103, 208, 772, 755, 623, 907, 438, 672, 314, 139, 939, 691, 215, 161, 137, 318, 738, 118, 453, 382, 773, 189, 307, 376, 795, 193, 275, 249, 687, 357, 481, 924, 856, 884, 988, 535, 966, 938, 357, 477, 380, 801, 610, 313, 586, 110, 760, 296, 618, 980, 937, 158, 993, 425, 657, 209, 481, 802, 746, 314, 436, 951, 105, 910, 141, 207, 202, 553, 349, 212, 730, 299, 561, 233, 647, 757, 124, 454, 805, 140, 895, 848, 325, 542, 232, 542, 512, 110, 401, 727, 359, 600, 664, 164, 341, 172, 211, 985, 843, 974, 492, 567, 396, 187, 910, 173, 303, 342, 305, 270, 362, 468, 417, 237, 614, 526, 640, 617, 661, 346, 845, 264, 113, 629, 444, 134, 112, 576, 558, 436, 175, 264, 711, 557, 830, 847, 642, 929, 658, 380, 935, 525, 139, 580, 772, 182, 807, 795, 506, 199, 464, 997, 260, 948, 885, 418, 997, 385, 679, 897, 983, 839, 938, 163, 119, 283, 365, 834, 684, 193, 642, 438, 207, 774, 516, 355, 958, 688, 741, 948, 835, 705, 161, 512, 271, 879, 639, 892, 319, 601, 946, 234, 822, 533, 811, 352, 973, 124, 539, 450, 920, 347, 858, 379, 821, 570, 382, 295, 112, 517, 349, 745, 498, 211, 988, 572, 677, 808, 587, 748, 767, 845, 989, 929, 187, 357, 454, 938, 460, 203, 685, 863, 371, 212, 813, 286, 535, 287, 453, 944, 874, 949, 606, 784, 789, 789, 480, 589, 240, 268, 659, 941, 774, 823, 628, 364, 996, 212, 450, 795, 125, 115, 110, 745, 820, 340, 175, 426, 931, 978, 478, 722, 748, 813, 707, 525, 950, 190, 234, 147, 121, 143, 573, 895, 602, 579, 973, 642, 168, 487, 920, 362, 708, 156, 300, 813, 221, 299, 981, 734, 834, 814, 409, 120, 404, 166, 196, 730, 744, 526, 837, 320, 151, 495, 897, 937, 892, 443, 744, 970, 427, 849, 509, 793, 165, 720, 671, 798, 734, 334, 181, 948, 936, 346, 919, 973, 904, 407, 235, 467, 566, 622, 605, 172, 625, 154, 973, 481, 671, 336, 584, 197, 533, 391, 695, 996, 677, 284, 397, 265, 972, 249, 958, 704, 432, 458, 610, 642, 751, 562, 606, 172, 902, 919, 848, 502, 882, 861, 596, 954, 372, 630, 797, 347, 858, 170, 904, 450, 142, 814, 570, 886, 248, 269, 706, 567, 183, 430, 447, 537, 802, 235, 951, 443, 684, 381, 602, 542, 305, 737, 514, 575, 424, 643, 555, 566, 880, 938, 265, 703, 351, 116, 501, 343, 110, 946, 128, 271, 413, 825, 657, 276, 198, 817, 984, 408, 888, 177, 764, 368, 927, 168, 118, 982, 345, 241, 136, 589, 902, 932, 220, 913, 166, 572, 520, 857, 178, 469, 279, 979, 376, 857, 883, 634, 851, 989, 606, 848, 761, 958, 174, 517, 503, 971, 256, 451, 661, 196, 428, 775, 830, 325, 113, 872, 618, 601, 345, 237, 602, 743, 571, 559, 572, 569, 723, 145, 771, 986, 756, 883, 388, 686, 434, 240, 233, 421, 766, 462, 549, 517, 111, 406, 709, 322, 428, 253, 779, 927, 261, 697, 741, 728, 550, 615, 200, 329, 255, 562, 612, 217, 255, 739, 513, 428, 217, 581, 400, 899, 469, 248, 331, 553, 238, 374, 913, 751, 909, 471, 379, 441, 325, 102, 543, 234, 146, 801, 429, 199, 521, 491, 635, 310, 963, 385, 738, 259, 481, 443, 917, 734, 613, 523, 707, 159, 185, 306, 404, 386, 364, 870, 251, 421, 331, 782, 690, 413, 731, 386, 863, 252, 190, 694, 578, 834, 484, 138, 483, 741, 259, 683, 800, 420, 432, 828, 826, 287, 323, 236, 816, 870, 994, 810, 494, 232, 562, 733, 709, 328, 255, 747, 994, 243, 392, 992, 654, 124, 158, 103, 609, 119, 676, 238, 976, 697, 452, 770, 121, 958, 761, 135, 718, 873, 704, 249, 869, 270, 230, 268, 688, 205, 317, 394, 862, 738, 230, 378, 457, 498, 139, 725, 192, 985, 340, 211, 791, 245, 825, 454, 444, 180, 240, 892, 996, 318, 958, 559, 261, 494, 385, 398, 178, 628, 803, 661, 130, 872, 979, 167, 131, 171, 384, 120, 212, 138, 265, 480, 948, 176, 648, 242, 245, 118, 352, 222, 387, 347, 689, 915, 646, 706, 530, 466, 938, 324, 512, 813, 906, 987, 868, 312, 230, 944, 722, 425, 880, 929, 931, 111, 572, 252, 409, 430, 922, 858, 942, 315, 113, 903, 213, 767, 625, 155, 728, 500, 605, 364, 411, 401, 304, 543, 702, 972, 545, 164, 445, 208, 631, 725, 821, 538, 283, 316, 907, 399, 334, 512, 581, 266, 964, 437, 332, 814, 311, 183, 209, 284, 149, 681, 514, 176, 574, 629, 361, 498, 587, 466, 443, 582, 184, 814, 848, 293, 745, 745, 152, 327, 497, 351, 825, 413, 594, 270, 965, 876, 709, 336, 869, 831, 419, 575, 512, 328, 292, 316, 725, 132, 558, 803, 257, 788, 196, 338, 948, 369, 463, 195, 923, 243, 182, 993, 139, 820, 936, 508, 658, 338, 324, 807, 380, 777, 350, 379, 894, 272, 477, 112, 410, 394, 675, 208, 498, 715, 498, 393, 183, 516, 254, 908, 833, 812, 318, 759, 809, 347, 767, 410, 530, 774, 691, 486, 837, 856, 111, 251, 723, 217, 707, 406, 448, 694, 494, 682, 708, 455, 680, 417, 308, 823, 266, 296, 103, 468, 347, 855, 667, 469, 558, 798, 798, 773, 981, 240, 516, 977, 178, 485, 781, 368, 384, 768, 746, 151, 867, 180, 155, 217, 776, 302, 176, 152, 218, 944, 190, 203, 581, 514, 770, 147, 117, 495, 848, 441, 699, 599, 647, 331, 273, 549, 455, 373, 489, 753, 408, 910, 445, 946, 536, 199, 773, 866, 250, 931, 405, 221, 525, 250, 262, 118, 163, 234, 601, 598, 511, 825, 946, 610, 348, 543, 317, 411, 962, 575, 760, 733, 562, 763, 269, 356, 308, 314, 560, 199, 447, 164, 943, 717, 346, 894, 386, 291, 544, 892, 533, 662, 252, 836, 680, 577, 553, 922, 418, 286, 803, 250, 989, 135, 440, 828, 222, 849, 302, 665, 588, 928, 162, 347, 250, 619, 268, 700, 754, 436, 680, 788, 133, 119, 870, 473, 602, 583, 607, 836, 114, 602, 699, 259, 730, 422, 155, 191, 575, 618, 687, 957, 972, 865, 196, 617, 424, 732, 510, 660, 514, 372, 521, 414, 315, 925, 601, 644, 988, 502, 411, 976, 808, 307, 399, 827, 276, 443, 308, 215, 254, 793, 975, 179, 401, 940, 260, 217, 718, 466, 729, 433, 200, 656, 412, 276, 482, 777, 406, 192, 734, 266, 860, 738, 206, 997, 274, 813, 540, 440, 696, 986, 472, 883, 384, 799, 626, 402, 220, 809, 949, 130, 239, 847, 965, 176, 110, 922, 265, 817, 523, 441, 443, 516, 491, 115, 426, 745, 560, 885, 406, 924, 407, 509, 658, 298, 625, 745, 801, 209, 350, 145, 842, 650, 580, 606, 872, 764, 566, 933, 883, 368, 492, 270, 301, 294, 665, 351, 230, 835, 852, 945, 691, 866, 534, 250, 211, 281, 524, 172, 656, 154, 683, 642, 397, 187, 940, 880, 481, 600, 557, 139, 560, 451, 671, 638, 750, 772, 616, 390, 335, 341, 419, 810, 938, 660, 116, 571, 344, 372, 778, 663, 473, 354, 698, 516, 815, 587, 109, 724, 750, 169, 882, 170, 214, 738, 406, 735, 125, 334, 268, 217, 868, 151, 924, 472, 419, 533, 850, 463, 365, 841, 655, 389, 678, 676, 266, 824, 203, 194, 678, 833, 708, 496, 710, 437, 863, 683, 148, 694, 391, 580, 135, 499, 429, 218, 542, 287, 496, 603, 334, 792, 507, 409, 150, 401, 911, 706, 767, 703, 796, 830, 266, 199, 335, 399, 951, 850, 263, 970, 445, 645, 296, 189, 860, 532, 732, 527, 575, 949, 623, 646, 416, 572, 531, 658, 738, 382, 311, 257, 525, 137, 470, 517, 872, 323, 247, 420, 724, 765, 289, 778, 670, 373, 919, 683, 935, 349, 814, 208, 980, 655, 227, 811, 827, 102, 407, 328, 305, 879, 378, 746, 946, 645, 170, 951, 598, 302, 121, 159, 798, 441, 552, 337, 242, 578, 666, 979, 203, 436, 284, 962, 326, 549, 397, 963, 649, 129, 199, 431, 605, 353, 569, 148, 816, 798, 309, 434, 457, 719, 497, 378, 406, 898, 909, 158, 685, 362, 476, 270, 472, 768, 952, 575, 151, 434, 808, 408, 302, 250, 695, 512, 257, 424, 436, 108, 398, 571, 484, 419, 108, 414, 333, 991, 379, 692, 635, 146, 567, 543, 832, 119, 843, 268, 194, 430, 620, 525, 684, 291, 880, 985, 652, 325, 250, 983, 829, 537, 893, 741, 881, 618, 196, 296, 775, 936, 550, 686, 289, 405, 662, 754, 238, 775, 292, 251, 970, 949, 810, 396, 898, 951, 469, 390, 614, 969, 406, 882, 108, 209, 259, 792, 202, 692, 476, 894, 765, 916, 564, 306, 919, 970, 334, 394, 770, 884, 384, 168, 762, 609, 370, 142, 421, 681, 831, 658, 988, 377, 745, 368, 719, 541, 460, 912, 977, 385, 760, 904, 315, 884, 204, 689, 319, 864, 774, 182, 546, 393, 907, 794, 222, 575, 779, 781, 996, 901, 926, 348, 690, 564, 452, 465, 935, 718, 328, 199, 229, 856, 154, 346, 595, 192, 994, 732, 873, 709, 876, 745, 420, 954, 696, 754, 682, 947, 521, 217, 649, 861, 485, 934, 997, 716, 746, 792, 303, 770, 633, 517, 161, 567, 136, 907, 743, 253, 198, 155, 180, 142, 469, 447, 700, 815, 931, 563, 882, 268, 697, 173, 380, 592, 940, 532, 171, 547, 928, 407, 581, 395, 490, 994, 703, 484, 839, 358, 626, 719, 538, 965, 1000, 804, 161, 633, 445, 232, 829, 114, 212, 598, 890, 555, 214, 481, 359, 641, 808, 217, 513, 219, 609, 241, 757, 787, 828, 918, 639, 399, 269, 603, 884, 407, 233, 545, 966, 323, 138, 841, 876, 496, 358, 956, 568, 772, 633, 383, 522, 126, 868, 593, 677, 113, 114, 998, 522, 191, 718, 667, 673, 736, 809, 779, 186, 482, 786, 625, 615, 269, 845, 658, 436, 433, 275, 458, 391, 508, 642, 113, 129, 500, 428, 254, 284, 288, 735, 296, 732, 727, 639, 958, 854, 693, 199, 238, 793, 165, 560, 233, 293, 864, 467, 736, 256, 826, 864, 773, 985, 133, 952, 628, 684, 672, 316, 380, 958, 870, 419, 276, 820, 639, 398, 618, 213, 159, 255, 361, 870, 208, 155, 212, 862, 746, 923, 861, 836, 651, 338, 270, 456, 825, 415, 433, 330, 476, 535, 859, 561, 190, 661, 835, 428, 716, 614, 306, 463, 188, 573, 439, 857, 440, 480, 224, 331, 875, 922, 568, 669, 664, 440, 644, 372, 716, 960, 947, 596, 571, 473, 894, 237, 166, 161, 258, 985, 640, 803, 576, 221, 233, 126, 815, 421, 510, 330, 169, 310, 456, 929, 120, 333, 536, 800, 237, 506, 716, 663, 724, 925, 378, 890, 520, 812, 749, 652, 629, 806, 186, 558, 188, 977, 446, 501, 231, 191, 381, 338, 264, 493, 342, 534, 727, 828, 349, 543, 529, 345, 715, 200, 122, 998, 389, 693, 131, 616, 502, 785, 109, 405, 472, 631, 358, 696, 848, 632, 778, 433, 192, 133, 183, 485, 429, 369, 328, 187, 576, 109, 873, 132, 179, 279, 488, 139, 781, 456, 680, 501, 854, 266, 327, 313, 746, 224, 127, 999, 419, 254, 847, 834, 590, 769, 277, 971, 211, 389, 492, 805, 176, 135, 199, 491, 937, 208, 144, 904, 438, 668, 550, 483, 214, 630, 429, 397, 223, 139, 335, 769, 642, 757, 800, 699, 234, 783, 445, 554, 990, 802, 652, 447, 293, 260, 394, 178, 206, 244, 902, 480, 533, 489, 619, 584, 765, 728, 462, 169, 940, 801, 401, 936, 918, 979, 313, 450, 236, 851, 540, 614, 914, 562, 162, 807, 692, 482, 241, 860, 162, 502, 657, 628, 489, 636, 404, 195, 352, 529, 534, 597, 758, 783, 730, 328, 984, 945, 927, 187, 349, 806, 563, 824, 953, 854, 888, 863, 791, 919, 296, 576, 391, 835, 143, 667, 416, 559, 782, 706, 352, 309, 429, 715, 506, 668, 294, 917, 496, 656, 213, 236, 972, 317, 125, 882, 393, 691, 212, 318, 194, 297, 516, 253, 143, 925, 513, 971, 883, 591, 446, 553, 582, 877, 283, 261, 607, 682, 171, 978, 606, 144, 389, 422, 837, 796, 554, 355, 846, 634, 998, 808, 695, 255, 151, 854, 449, 877, 757, 679, 197, 763, 504, 416, 133, 961, 744, 395, 922, 321, 187, 394, 208, 275, 847, 580, 676, 192, 918, 841, 263, 331, 276, 293, 678, 855, 173, 586, 696, 975, 327, 840, 511, 175, 655, 110, 728, 771, 251, 832, 426, 980, 107, 410, 877, 828, 705, 277, 398, 456, 883, 956, 230, 830, 977, 710, 128, 813, 217, 774, 879, 518, 822, 373, 106, 367, 418, 492, 991, 679, 767, 950, 669, 986, 848, 936, 611, 936, 600, 317, 413, 377, 153, 812, 205, 440, 356, 478, 264, 786, 859, 882, 203, 358, 842, 444, 949, 193, 594, 429, 237, 792, 960, 962, 969, 623, 229, 333, 301, 759, 503, 440, 831, 575, 653, 575, 937, 470, 415, 387, 978, 163, 959, 471, 450, 103, 286, 883, 184, 947, 351, 748, 477, 441, 772, 967, 574, 805, 874, 898, 678, 621, 305, 297, 199, 648, 716, 228, 340, 110, 218, 640, 983, 685, 442, 246, 529, 689, 994, 496, 739, 982, 996, 147, 108, 840, 231, 523, 532, 919, 210, 109, 942, 371, 294, 325, 503, 403, 233, 904, 117, 625, 718, 136, 104, 110, 982, 393, 741, 810, 246, 415, 256, 275, 188, 972, 191, 120, 752, 927, 921, 747, 788, 668, 475, 886, 651, 196, 222, 599, 818, 285, 920, 977, 101, 977, 392, 903, 289, 631, 106, 308, 374, 467, 619, 839, 584, 857, 168, 728, 406, 750, 391, 157, 249, 474, 553, 513, 835, 900, 507, 601, 646, 433, 232, 411, 720, 781, 140, 300, 358, 966, 360, 491, 363, 725, 513, 248, 248, 736, 998, 237, 426, 745, 923, 221, 492, 868, 831, 825, 558, 113, 137, 812, 484, 422, 144, 415, 632, 486, 808, 363, 407, 337, 351, 562, 966, 246, 477, 997, 586, 557, 673, 405, 614, 216, 194, 793, 446, 766, 573, 699, 667, 733, 518, 285, 390, 668, 857, 670, 355, 713, 302, 667, 805, 714, 712, 703, 101, 793, 390, 864, 434, 546, 207, 323, 776, 907, 466, 619, 871, 172, 805, 592, 309, 958, 741, 475, 267, 399, 503, 792, 306, 340, 821, 512, 634, 181, 894, 801, 569, 478, 242, 648, 111, 114, 424, 659, 458, 912, 387, 779, 325, 343, 715, 223, 382, 650, 923, 229, 191, 820, 385, 272, 874, 232, 734, 680, 123, 471, 126, 952, 108, 170, 338, 764, 134, 328, 520, 611, 603, 701, 741, 879, 191, 923, 394, 155, 664, 205, 998, 396, 638, 709, 673, 759, 153, 287, 871, 754, 806, 406, 317, 333, 472, 686, 999, 689, 777, 673, 230, 591, 637, 893, 510, 138, 737, 570, 173, 340, 779, 244, 938, 542, 322, 412, 722, 817, 784, 694, 518, 227, 742, 833, 191, 751, 853, 914, 532, 206, 525, 364, 996, 497, 803, 740, 118, 666, 390, 935, 511, 580, 748, 214, 363, 523, 135, 753, 969, 631, 127, 519, 157, 829, 246, 212, 154, 338, 510, 190, 454, 717, 491, 533, 320, 932, 824, 266, 652, 156, 773, 410, 911, 631, 828, 475, 756, 891, 507, 111, 157, 186, 863, 189, 419, 118, 845, 325, 222, 305, 635, 732, 238, 748, 988, 470, 944, 304, 234, 808, 553, 708, 622, 498, 995, 913, 393, 157, 904, 158, 509, 847, 132, 400, 847, 968, 923, 816, 460, 953, 287, 133, 751, 380, 551, 310, 333, 241, 600, 572, 521, 293, 839, 679, 389, 861, 205, 530, 429, 474, 190, 722, 620, 332, 348, 291, 537, 707, 725, 932, 346, 662, 997, 721, 685, 835, 676, 621, 707, 161, 687, 757, 360, 128, 748, 782, 255, 949, 420, 915, 826, 930, 563, 824, 185, 177, 751, 374, 734, 804, 230, 436, 280, 592, 502, 343, 706, 885, 737, 584, 963, 919, 864, 585, 105, 789, 661, 665, 164, 509, 689, 835, 613, 165, 166, 160, 537, 364, 153, 835, 720, 233, 458, 621, 257, 791, 760, 600, 524, 179, 978, 808, 416, 633, 386, 850, 901, 350, 892, 334, 504, 750, 268, 482, 870, 148, 410, 690, 544, 964, 479, 188, 594, 837, 717, 382, 561, 463, 733, 102, 584, 738, 804, 679, 269, 644, 211, 611, 625, 221, 332, 855, 383, 462, 741, 547, 731, 509, 291, 692, 285, 623, 402, 273, 264, 604, 348, 694, 623, 590, 401, 555, 460, 954, 151, 669, 346, 239, 634, 321, 250, 973, 342, 165, 590, 630, 369, 892, 309, 211, 533, 649, 533, 655, 146, 215, 833, 856, 205, 643, 469, 195, 458, 226, 313, 801, 110, 283, 228, 917, 964, 740, 877, 941, 680, 726, 480, 269, 510, 600, 816, 665, 949, 225, 415, 579, 315, 510, 643, 574, 370, 137, 480, 398, 292, 833, 259, 119, 114, 525, 479, 341, 560, 361, 953, 285, 873, 933, 653, 539, 206, 901, 878, 236, 194, 565, 428, 102, 972, 666, 582, 850, 534, 561, 635, 841, 421, 688, 701, 621, 658, 977, 836, 299, 710, 635, 870, 480, 692, 239, 942, 850, 738, 175, 578, 174, 213, 801, 527, 160, 321, 887, 431, 210, 382, 537, 569, 558, 528, 452, 529, 601, 130, 840, 912, 701, 795, 485, 948, 722, 729, 953, 220, 557, 129, 879, 631, 335, 734, 633, 126, 279, 998, 764, 152, 390, 757, 491, 502, 931, 560, 653, 149, 533, 125, 775, 142, 667, 810, 913, 723, 443, 508, 479, 243, 882, 220, 689, 207, 352, 931, 976, 686, 801, 141, 234, 538, 851, 468, 615, 855, 930, 926, 801, 975, 951, 723, 287, 327, 206, 277, 909, 131, 225, 187, 409, 825, 816, 911, 901, 193, 646, 867, 892, 612, 184, 149, 898, 346, 608, 921, 374, 745, 860, 687, 146, 588, 541, 212, 116, 732, 265, 854, 312, 453, 703, 159, 523, 782, 508, 839, 171, 847, 894, 839, 517, 879, 643, 444, 287, 669, 840, 891, 998, 691, 603, 789, 326, 429, 719, 787, 940, 890, 452, 104, 864, 421, 994, 583, 579, 170, 553, 829, 988, 110, 430, 861, 841, 507, 759, 249, 671, 361, 995, 263, 666, 777, 761, 817, 417, 355, 863, 294, 227, 732, 795, 817, 689, 861, 616, 282, 271, 457, 491, 974, 818, 312, 825, 244, 887, 852, 302, 872, 269, 192, 577, 319, 202, 511, 656, 560, 666, 462, 418, 744, 719, 288, 450, 159, 311, 425, 951, 888, 690, 705, 553, 594, 500, 703, 708, 952, 149, 954, 890, 726, 835, 840, 669, 957, 571, 870, 429, 589, 697, 977, 670, 630, 418, 268, 812, 529, 939, 130, 740, 924, 456, 188, 152, 434, 935, 671, 994, 680, 936, 857, 460, 227, 309, 760, 867, 486, 402, 409, 327, 623, 391, 154, 598, 813, 617, 315, 725, 259, 381, 677, 313, 478, 720, 662, 284, 262, 996, 362, 118, 343, 303, 804, 371, 906, 560, 719, 257, 714, 670, 378, 575, 837, 322, 125, 213, 993, 916, 184, 275, 461, 429, 252, 620, 659, 404, 721, 570, 163, 533, 340, 654, 543, 517, 224, 102, 130, 221, 362, 815, 414, 872, 888, 409, 453, 863, 419, 765, 442, 181, 592, 125, 350, 113, 380, 939, 591, 685, 394, 201, 654, 752, 556, 242, 438, 485, 130, 590, 994, 893, 384, 669, 650, 230, 466, 472, 227, 927, 879, 261, 231, 210, 160, 579, 465, 549, 483, 316, 978, 906, 284, 641, 988, 411, 333, 236, 984, 743, 769, 934, 383, 379, 533, 283, 649, 132, 606, 947, 285, 726, 493, 793, 363, 894, 878, 535, 729, 776, 228, 530, 463, 198, 130, 330, 665, 639, 302, 633, 174, 213, 405, 922, 876, 911, 640, 769, 359, 571, 940, 517, 935, 897, 931, 209, 156, 165, 224, 540, 279, 686, 946, 707, 557, 183, 601, 553, 813, 546, 606, 907, 625, 190, 646, 118, 117, 949, 771, 513, 783, 953, 397, 376, 780, 157, 413, 649, 554, 686, 960, 730, 746, 858, 352, 498, 543, 187, 529, 171, 688, 787, 889, 443, 547, 175, 528, 691, 432, 706, 989, 629, 980, 556, 791, 354, 148, 880, 632, 487, 263, 395, 633, 728, 921, 264, 923, 353, 609, 166, 836, 882, 574, 603, 390, 500, 786, 777, 894, 992, 725, 572, 137, 577, 170, 153, 258, 924, 893, 332, 228, 687, 394, 796, 391, 325, 347, 774, 726, 503, 501, 241, 928, 362, 861, 621, 166, 284, 248, 511, 748, 345, 447, 949, 632, 476, 149, 949, 792, 514, 356, 313, 205, 727, 113, 962, 980, 444, 133, 992, 110, 559, 548, 645, 605, 788, 927, 658, 614, 835, 119, 163, 388, 827, 656, 485, 501, 918, 531, 288, 824, 845, 979, 282, 265, 926, 874, 994, 420, 293, 377, 771, 178, 953, 145, 778, 572, 398, 818, 862, 323, 349, 538, 136, 789, 342, 890, 815, 926, 549, 678, 910, 869, 642, 440, 182, 335, 773, 481, 565, 334, 818, 453, 901, 133, 819, 830, 992, 814, 559, 192, 191, 102, 945, 326, 240, 370, 161, 640, 776, 588, 599, 340, 393, 388, 617, 229, 519, 491, 484, 320, 959, 413, 138, 640, 952, 334, 213, 274, 757, 507, 142, 751, 401, 949, 281, 305, 413, 401, 699, 680, 387, 474, 899, 131, 879, 526, 215, 973, 176, 257, 244, 406, 227, 919, 615, 613, 691, 389, 286, 285, 808, 167, 898, 283, 550, 528, 471, 556, 784, 713, 512, 731, 647, 213, 317, 594, 923, 216, 191, 562, 162, 126, 443, 243, 356, 622, 391, 707, 719, 782, 733, 262, 447, 909, 162, 169, 969, 326, 543, 459, 752, 268, 646, 546, 120, 208, 610, 935, 945, 669, 290, 980, 932, 524, 502, 993, 501, 575, 354, 971, 539, 311, 273, 461, 959, 696, 340, 215, 890, 115, 511, 862, 824, 109, 318, 184, 420, 286, 740, 559, 787, 445, 289, 460, 193, 970, 164, 452, 899, 199, 245, 768, 925, 167, 315, 929, 637, 130, 790, 700, 935, 724, 116, 190, 701, 190, 714, 885, 126, 407, 181, 906, 107, 573, 840, 600, 688, 982, 112, 604, 274, 613, 268, 823, 241, 362, 892, 327, 187, 651, 832, 971, 276, 486, 261, 303, 381, 326, 303, 181, 580, 525, 390, 808, 586, 300, 483, 594, 675, 442, 118, 727, 399, 748, 729, 217, 787, 670, 752, 213, 647, 363, 521, 357, 247, 934, 779, 756, 733, 147, 287, 446, 910, 907, 390, 498, 572, 706, 966, 538, 258, 572, 166, 413, 648, 698, 197, 889, 512, 645, 908, 473, 236, 777, 929, 148, 713, 511, 299, 692, 908, 126, 274, 840, 477, 619, 731, 122, 242, 519, 909, 892, 692, 507, 159, 177, 825, 870, 573, 796, 550, 816, 529, 627, 866, 513, 936, 731, 396, 175, 205, 101, 958, 694, 130, 373, 814, 333, 822, 842, 290, 664, 139, 730, 616, 767, 565, 661, 473, 513, 852, 189, 338, 926, 982, 284, 666, 389, 578, 755, 196, 431, 687, 848, 220, 996, 785, 601, 461, 167, 258, 220, 495, 115, 188, 267, 513, 498, 408, 625, 661, 789, 596, 211, 884, 700, 601, 357, 875, 671, 451, 196, 527, 852, 412, 419, 454, 460, 947, 462, 190, 372, 287, 412, 697, 722, 252, 186, 489, 836, 843, 507, 372, 797, 277, 769, 704, 319, 437, 598, 865, 472, 301, 757, 748, 230, 172, 371, 843, 785, 944, 798, 714, 931, 670, 891, 211, 881, 605, 301, 663, 205, 655, 996, 183, 488, 418, 624, 623, 207, 354, 466, 133, 973, 419, 940, 543, 859, 392, 862, 992, 532, 514, 282, 221, 338, 671, 462, 493, 241, 349, 499, 751, 832, 969, 745, 979, 445, 480, 522, 649, 573, 716, 421, 493, 402, 415, 406, 223, 937, 538, 791, 302, 277, 168, 132, 433, 699, 686, 561, 122, 597, 472, 487, 113, 951, 497, 520, 389, 150, 942, 980, 282, 222, 584, 998, 536, 590, 525, 154, 723, 499, 254, 171, 779, 410, 620, 962, 958, 594, 560, 275, 612, 419, 856, 692, 559, 207, 651, 216, 638, 439, 548, 791, 777, 738, 227, 848, 957, 143, 692, 908, 377, 845, 399, 985, 776, 648, 137, 969, 237, 365, 775, 771, 992, 727, 813, 888, 212, 643, 321, 971, 823, 624, 513, 848, 822, 925, 926, 450, 534, 648, 408, 488, 129, 779, 782, 352, 319, 832, 166, 755, 823, 245, 673, 460, 829, 777, 543, 979, 268, 315, 278, 648, 874, 890, 983, 270, 611, 537, 683, 202, 489, 496, 609, 234, 767, 961, 972, 816, 626, 378, 404, 501, 270, 186, 657, 357, 387, 501, 143, 431, 381, 387, 271, 542, 174, 429, 915, 637, 918, 387, 635, 538, 212, 237, 922, 893, 251, 728, 822, 380, 287, 353, 203, 450, 444, 437, 531, 411, 885, 670, 731, 810, 274, 515, 299, 922, 971, 767, 869, 565, 172, 717, 212, 511, 746, 385, 893, 499, 864, 662, 117, 644, 653, 300, 410, 105, 678, 728, 274, 899, 502, 163, 605, 377, 208, 666, 137, 439, 852, 284, 317, 710, 883, 184, 348, 169, 651, 942, 788, 980, 284, 331, 652, 307, 202, 880, 604, 348, 456, 635, 203, 349, 335, 773, 273, 743, 636, 957, 268, 538, 728, 527, 731, 518, 186, 132, 365, 667, 352, 748, 335, 419, 525, 481, 720, 567, 211, 429, 280, 170, 421, 345, 105, 881, 223, 304, 782, 526, 881, 709, 756, 979, 508, 794, 398, 594, 973, 569, 617, 130, 227, 312, 142, 292, 181, 184, 191, 286, 277, 822, 439, 511, 889, 134, 643, 447, 658, 550, 565, 581, 501, 345, 959, 590, 541, 146, 118, 792, 385, 561, 185, 237, 296, 162, 549, 374, 289, 874, 674, 244, 557, 810, 897, 558, 261, 901, 964, 292, 834, 713, 136, 860, 152, 670, 289, 752, 942, 990, 133, 235, 330, 830, 809, 261, 676, 767, 635, 984, 481, 362, 288, 667, 171, 675, 900, 506, 132, 747, 799, 143, 448, 465, 268, 712, 193, 333, 194, 165, 970, 653, 134, 930, 619, 366, 754, 858, 200, 541, 792, 731, 555, 545, 349, 946, 888, 268, 660, 497, 876, 860, 108, 381, 872, 293, 217, 833, 354, 888, 141, 990, 595, 431, 237, 811, 954, 857, 823, 519, 186, 691, 515, 460, 786, 988, 817, 843, 867, 545, 916, 782, 596, 471, 598, 768, 466, 662, 771, 634, 533, 257, 813, 961, 924, 390, 324, 657, 584, 606, 576, 915, 457, 925, 280, 238, 568, 997, 987, 887, 608, 236, 438, 359, 985, 210, 193, 539, 870, 575, 729, 293, 746, 215, 415, 970, 242, 288, 311, 427, 954, 550, 902, 944, 547, 228, 551, 354, 119, 852, 743, 980, 848, 660, 198, 351, 973, 468, 298, 147, 652, 899, 261, 507, 457, 557, 140, 121, 725, 932, 771, 933, 713, 445, 622, 470, 222, 793, 915, 158, 682, 740, 548, 242, 969, 606, 671, 160, 708, 469, 355, 975, 242, 483, 373, 403, 871, 108, 276, 386, 965, 114, 718, 495, 731, 763, 351, 120, 328, 469, 440, 599, 609, 385, 795, 775, 279, 253, 530, 393, 636, 960, 772, 239, 435, 269, 750, 966, 557, 817, 181, 612, 808, 815, 917, 700, 392, 923, 709, 348, 584, 852, 374, 460, 892, 558, 447, 458, 697, 672, 575, 209, 565, 164, 702, 862, 258, 850, 205, 391, 604, 120, 688, 979, 820, 290, 414, 654, 796, 896, 509, 570, 229, 869, 934, 216, 853, 248, 978, 406, 803, 512, 873, 872, 949, 475, 410, 171, 313, 674, 810, 409, 442, 823, 374, 880, 818, 375, 611, 217, 834, 664, 573, 947, 677, 309, 883, 879, 570, 946, 994, 883, 610, 984, 752, 719, 852, 818, 509, 116, 789, 916, 125, 377, 629, 170, 744, 696, 671, 121, 602, 494, 890, 481, 760, 998, 145, 641, 990, 435, 347, 808, 369, 343, 777, 528, 932, 152, 646, 516, 995, 243, 642, 603, 711, 574, 391, 918, 315, 915, 136, 419, 860, 745, 177, 586, 950, 301, 846, 501, 330, 792, 886, 408, 945, 960, 769, 924, 161, 227, 869, 324, 342, 613, 151, 602, 108, 731, 872, 436, 817, 643, 762, 399, 574, 539, 981, 888, 506, 554, 173, 269, 297, 659, 970, 648, 424, 207, 130, 720, 286, 126, 620, 101, 486, 425, 396, 856, 802, 536, 724, 875, 664, 688, 616, 821, 949, 234, 917, 956, 431, 214, 101, 405, 564, 251, 690, 505, 534, 820, 716, 739, 173, 250, 716, 768, 926, 405, 185, 859, 335, 120, 427, 388, 671, 564, 390, 754, 418, 496, 442, 842, 326, 766, 243, 554, 142, 163, 282, 487, 183, 132, 436, 741, 771, 270, 519, 548, 576, 303, 250, 128, 348, 803, 718, 265, 432, 296, 701, 608, 823, 537, 702, 933, 666, 574, 408, 397, 119, 609, 221, 732, 837, 631, 894, 868, 403, 825, 803, 596, 986, 920, 579, 228, 446, 422, 368, 911, 876, 138, 252, 961, 450, 355, 227, 345, 541, 354, 737, 416, 636, 476, 664, 798, 668, 200, 554, 197, 511, 776, 758, 842, 456, 216, 424, 174, 809, 169, 197, 879, 689, 518, 682, 455, 851, 207, 526, 380, 640, 361, 514, 485, 255, 350, 130, 918, 921, 613, 461, 398, 444, 957, 762, 780, 183, 435, 887, 593, 842, 621, 507, 207, 291, 250, 584, 731, 918, 814, 586, 596, 483, 431, 868, 806, 739, 996, 139, 993, 257, 152, 938, 157, 482, 297, 471, 123, 793, 610, 880, 162, 940, 230, 955, 151, 611, 567, 749, 497, 431, 518, 406, 492, 175, 426, 253, 574, 478, 401, 879, 587, 402, 639, 722, 922, 393, 821, 742, 738, 447, 304, 180, 445, 562, 460, 142, 361, 351, 341, 477, 671, 797, 900, 710, 462, 199, 450, 185, 113, 882, 306, 414, 688, 261, 696, 913, 856, 277, 978, 830, 801, 997, 276, 983, 285, 896, 676, 475, 342, 134, 751, 120, 802, 673, 424, 125, 822, 268, 245, 162, 709, 722, 642, 437, 727, 250, 643, 708, 371, 116, 124, 990, 708, 450, 717, 786, 620, 154, 591, 221, 810, 939, 133, 604, 928, 114, 585, 424, 228, 828, 104, 393, 136, 407, 388, 119, 203, 624, 278, 400, 914, 473, 508, 777, 833, 228, 461, 530, 510, 480, 718, 143, 628, 210, 769, 719, 103, 220, 190, 108, 967, 112, 396, 683, 314, 140, 959, 161, 764, 491, 983, 607, 379, 991, 481, 811, 610, 453, 650, 253, 168, 968, 346, 395, 627, 594, 358, 410, 331, 231, 751, 517, 207, 718, 509, 885, 975, 761, 782, 526, 218, 830, 580, 157, 755, 465, 832, 521, 117, 203, 448, 945, 859, 786, 990, 263, 704, 942, 691, 942, 219, 354, 728, 253, 897, 196, 175, 453, 542, 570, 876, 308, 379, 315, 804, 804, 227, 920, 400, 426, 371, 159, 735, 795, 298, 635, 956, 392, 558, 641, 375, 671, 697, 955, 861, 320, 294, 952, 754, 503, 937, 815, 304, 857, 192, 157, 167, 656, 182, 207, 166, 563, 394, 176, 369, 907, 877, 812, 451, 721, 599, 205, 111, 488, 517, 541, 359, 354, 281, 203, 114, 318, 963, 476, 921, 645, 619, 520, 124, 733, 642, 869, 776, 516, 619, 217, 404, 806, 233, 944, 399, 677, 301, 204, 624, 275, 388, 128, 626, 758, 664, 730, 777, 227, 767, 156, 667, 316, 380, 961, 581, 742, 632, 203, 259, 818, 803, 153, 503, 925, 702, 866, 444, 211, 597, 856, 145, 351, 216, 714, 155, 648, 677, 679, 267, 707, 471, 295, 678, 225, 847, 862, 899, 144, 469, 318, 224, 569, 854, 164, 531, 469, 514, 141, 294, 420, 708, 720, 462, 501, 850, 170, 979, 214, 386, 193, 991, 308, 108, 939, 121, 590, 325, 475, 552, 752, 685, 621, 268, 682, 934, 578, 774, 727, 376, 383, 130, 381, 415, 896, 666, 496, 191, 761, 159, 992, 589, 162, 202, 614, 550, 629, 347, 357, 650, 913, 111, 300, 199, 209, 808, 649, 683, 767, 389, 459, 810, 448, 793, 886, 632, 462, 674, 985, 706, 910, 130, 427, 119, 662, 666, 495, 432, 850, 526, 745, 516, 533, 802, 618, 483, 737, 143, 852, 765, 220, 426, 582, 283, 860, 619, 506, 195, 896, 108, 542, 831, 223, 670, 182, 768, 420, 393, 116, 848, 988, 927, 878, 574, 483, 676, 814, 238, 351, 744, 910, 904, 515, 690, 886, 241, 922, 882, 658, 616, 778, 281, 190, 793, 400, 828, 412, 316, 876, 925, 703, 992, 626, 358, 542, 511, 342, 117, 679, 553, 727, 533, 176, 952, 258, 365, 648, 110, 379, 657, 430, 722, 132, 276, 168, 715, 434, 188, 401, 566, 522, 618, 506, 977, 438, 102, 988, 780, 576, 419, 545, 949, 924, 132, 241, 508, 402, 153, 850, 497, 166, 247, 632, 571, 812, 415, 898, 433, 117, 800, 986, 916, 437, 596, 360, 163, 550, 768, 144, 594, 613, 726, 948, 444, 946, 881, 167, 477, 646, 723, 725, 221, 293, 956, 374, 698, 956, 414, 391, 235, 252, 598, 297, 944, 606, 623, 625, 198, 585, 159, 139, 121, 366, 489, 858, 507, 144, 665, 856, 803, 114, 109, 733, 580, 367, 405, 564, 865, 349, 899, 943, 600, 547, 660, 223, 575, 530, 832, 468, 348, 709, 216, 424, 667, 528, 700, 926, 663, 223, 857, 869, 723, 324, 104, 882, 556, 292, 761, 380, 730, 473, 663, 989, 448, 836, 390, 791, 917, 492, 876, 394, 314, 840, 532, 134, 403, 943, 585, 747, 215, 481, 693, 107, 614, 747, 409, 906, 209, 265, 137, 873, 416, 607, 163, 458, 686, 441, 578, 366, 988, 412, 806, 513, 731, 275, 541, 461, 956, 798, 897, 478, 861, 919, 199, 267, 745, 960, 539, 663, 303, 563, 784, 401, 795, 340, 875, 927, 423, 269, 808, 130, 487, 766, 348, 427, 367, 856, 712, 863, 382, 767, 638, 445, 114, 963, 456, 814, 651, 200, 460, 929, 577, 820, 309, 553, 911, 382, 285, 920, 989, 199, 769, 787, 874, 519, 196, 901, 205, 992, 724, 479, 269, 413, 256, 704, 628, 664, 898, 140, 150, 223, 903, 491, 611, 501, 760, 355, 305, 872, 472, 779, 634, 532, 150, 476, 492, 714, 585, 760, 649, 333, 357, 383, 483, 931, 496, 659, 478, 788, 697, 941, 242, 140, 364, 236, 840, 334, 717, 322, 747, 152, 705, 619, 702, 839, 882, 685, 149, 769, 426, 396, 171, 210, 469, 237, 163, 592, 753, 749, 328, 630, 468, 332, 262, 408, 295, 741, 258, 473, 268, 199, 304, 222, 783, 262, 801, 593, 605, 296, 440, 406, 670, 133, 805, 239, 516, 234, 260, 861, 915, 800, 249, 966, 400, 552, 551, 838, 835, 937, 988, 240, 308, 710, 189, 759, 238, 207, 716, 183, 884, 171, 614, 477, 229, 873, 130, 519, 839, 667, 673, 895, 961, 994, 590, 452, 220, 365, 953, 889, 474, 479, 365, 544, 402, 964, 426, 528, 178, 657, 482, 838, 753, 451, 704, 738, 115, 778, 972, 603, 768, 417, 843, 842, 880, 928, 439, 459, 375, 346, 634, 424, 747, 428, 273, 621, 634, 119, 560, 284, 898, 168, 391, 252, 242, 790, 175, 349, 992, 780, 355, 496, 232, 237, 659, 124, 316, 803, 344, 284, 863, 426, 257, 198, 283, 814, 346, 692, 784, 379, 118, 778, 216, 152, 861, 653, 637, 568, 125, 834, 556, 768, 868, 479, 128, 846, 148, 933, 677, 935, 829, 904, 166, 336, 573, 268, 952, 520, 359, 769, 901, 437, 434, 287, 937, 649, 995, 809, 816, 814, 191, 445, 196, 816, 376, 913, 477, 170, 267, 208, 540, 579, 828, 655, 875, 432, 326, 302, 757, 382, 440, 829, 370, 145, 881, 322, 913, 614, 679, 270, 745, 935, 111, 198, 878, 364, 638, 661, 510, 505, 328, 311, 342, 396, 776, 487, 884, 768, 457, 840, 661, 265, 838, 181, 392, 708, 396, 583, 140, 649, 105, 390, 207, 561, 892, 722, 717, 165, 917, 758, 922, 626, 336, 154, 166, 287, 505, 509, 246, 123, 333, 556, 577, 639, 234, 714, 120, 847, 347, 154, 661, 697, 285, 800, 437, 824, 400, 244, 409, 903, 985, 336, 250, 103, 928, 409, 709, 204, 693, 168, 943, 915, 269, 321, 902, 160, 737, 522, 698, 954, 410, 455, 106, 390, 491, 306, 415, 887, 404, 832, 503, 648, 181, 718, 767, 739, 460, 426, 891, 687, 829, 871, 600, 948, 849, 769, 151, 293, 994, 702, 795, 447, 912, 107, 344, 120, 884, 459, 223, 292, 639, 544, 731, 359, 358, 620, 534, 674, 122, 251, 859, 869, 992, 604, 333, 956, 153, 814, 188, 882, 532, 594, 997, 282, 143, 605, 575, 997, 479, 352, 176, 125, 600, 368, 926, 297, 593, 555, 306, 159, 891, 655, 475, 538, 971, 261, 176, 851, 777, 729, 998, 528, 236, 625, 801, 842, 696, 927, 734, 904, 357, 655, 255, 857, 693, 747, 739, 670, 826, 295, 101, 205, 107, 592, 198, 101, 698, 386, 191, 900, 704, 477, 891, 421, 910, 337, 171, 867, 198, 926, 939, 491, 719, 344, 110, 286, 625, 396, 349, 192, 766, 965, 493, 766, 117, 852, 359, 788, 114, 832, 665, 892, 875, 903, 150, 792, 657, 804, 363, 727, 551, 718, 339, 641, 711, 447, 441, 814, 964, 746, 813, 546, 900, 664, 726, 217, 412, 182, 917, 114, 367, 717, 120, 209, 735, 840, 713, 803, 936, 388, 136, 253, 531, 586, 370, 824, 652, 523, 676, 698, 630, 866, 857, 336, 926, 218, 986, 538, 973, 764, 750, 199, 739, 992, 104, 955, 754, 670, 834, 326, 314, 628, 393, 826, 948, 661, 379, 493, 532, 970, 469, 666, 638, 583, 434, 542, 973, 951, 723, 298, 786, 222, 456, 574, 596, 982, 919, 974, 269, 117, 636, 372, 965, 479, 433, 670, 625, 472, 312, 338, 406, 242, 167, 655, 814, 565, 322, 778, 564, 663, 368, 132, 932, 644, 684, 737, 618, 950, 227, 369, 411, 655, 769, 783, 250, 279, 522, 973, 922, 367, 319, 779, 961, 741, 408, 398, 236, 148, 176, 287, 234, 808, 549, 874, 543, 982, 697, 200, 804, 370, 503, 171, 393, 651, 610, 242, 422, 705, 328, 887, 946, 348, 300, 652, 134, 827, 283, 991, 414, 849, 712, 316, 754, 712, 912, 576, 783, 411, 682, 833, 897, 766, 747, 949, 906, 662, 322, 908, 415, 273, 681, 263, 153, 726, 849, 928, 996, 983, 160, 252, 949, 136, 119, 511, 725, 417, 376, 424, 131, 976, 444, 206, 568, 430, 538, 261, 894, 965, 706, 373, 509, 330, 736, 624, 420, 371, 125, 125, 327, 882, 503, 550, 147, 346, 547, 803, 625, 119, 560, 634, 628, 157, 542, 673, 945, 493, 713, 487, 919, 147, 424, 445, 148, 364, 804, 605, 273, 738, 670, 405, 415, 949, 777, 853, 101, 192, 790, 504, 489, 185, 509, 961, 944, 147, 977, 427, 773, 619, 188, 915, 806, 600, 862, 182, 605, 131, 955, 151, 253, 541, 647, 246, 814, 755, 319, 732, 408, 1000, 101, 527, 744, 845, 755, 846, 627, 759, 826, 131, 159, 530, 540, 880, 431, 307, 786, 522, 665, 202, 857, 391, 659, 542, 181, 545, 156, 844, 899, 168, 275, 867, 967, 834, 765, 303, 895, 990, 408, 187, 558, 756, 278, 826, 904, 370, 184, 473, 405, 725, 888, 880, 306, 522, 727, 221, 158, 964, 507, 176, 769, 728, 844, 915, 561, 511, 688, 803, 302, 395, 587, 318, 897, 528, 285, 612, 394, 462, 427, 344, 144, 626, 756, 174, 619, 623, 656, 391, 449, 689, 304, 907, 166, 903, 293, 300, 680, 457, 749, 902, 894, 273, 620, 518, 175, 206, 632, 399, 569, 637, 581, 913, 365, 714, 149, 603, 477, 612, 576, 817, 286, 318, 429, 377, 796, 130, 803, 185, 242, 222, 399, 960, 847, 701, 568, 806, 798, 940, 739, 757, 114, 331, 722, 960, 167, 247, 486, 557, 356, 161, 591, 912, 234, 423, 670, 534, 352, 509, 769, 902, 761, 482, 465, 847, 681, 695, 319, 479, 296, 456, 238, 578, 230, 345, 686, 804, 313, 561, 346, 298, 608, 526, 109, 539, 780, 311, 579, 343, 980, 305, 445, 473, 643, 808, 399, 850, 742, 685, 792, 990, 354, 276, 352, 930, 568, 233, 265, 609, 736, 568, 702, 212, 905, 704, 903, 433, 442, 297, 129, 801, 892, 263, 681, 413, 635, 603, 149, 747, 618, 741, 965, 820, 859, 131, 329, 357, 710, 942, 490, 158, 289, 483, 221, 278, 316, 789, 182, 608, 190, 282, 806, 663, 282, 382, 246, 183, 618, 131, 689, 342, 974, 348, 530, 278, 840, 331, 909, 470, 858, 134, 453, 685, 401, 658, 157, 501, 648, 329, 594, 830, 323, 890, 659, 743, 306, 900, 632, 610, 427, 524, 874, 202, 311, 240, 399, 441, 167, 928, 960, 667, 864, 480, 812, 730, 626, 967, 120, 651, 393, 216, 556, 699, 505, 758, 942, 719, 822, 670, 960, 219, 241, 865, 326, 522, 380, 693, 738, 704, 141, 309, 548, 753, 850, 766, 869, 438, 280, 923, 377, 326, 955, 843, 185, 682, 201, 761, 776, 906, 510, 822, 194, 726, 378, 292, 425, 270, 678, 700, 398, 900, 368, 271, 309, 565, 537, 833, 207, 655, 153, 463, 856, 264, 552, 435, 284, 336, 936, 427, 400, 406, 577, 105, 944, 662, 758, 458, 986, 547, 747, 988, 907, 377, 127, 219, 569, 443, 802, 711, 534, 247, 545, 943, 432, 576, 620, 747, 976, 376, 752, 204, 921, 382, 532, 239, 492, 628, 930, 511, 799, 973, 793, 225, 971, 502, 283, 611, 319, 460, 945, 322, 666, 285, 869, 458, 704, 791, 305, 971, 421, 597, 431, 300, 365, 902, 607, 133, 133, 559, 678, 312, 492, 430, 244, 727, 621, 957, 705, 645, 604, 738, 366, 968, 656, 255, 688, 432, 419, 260, 140, 744, 534, 225, 420, 399, 741, 505, 806, 269, 707, 493, 475, 810, 921, 232, 968, 146, 929, 665, 543, 755, 654, 221, 173, 147, 246, 227, 666, 815, 915, 711, 944, 274, 421, 211, 119, 463, 675, 726, 580, 375, 129, 981, 370, 778, 780, 199, 543, 617, 608, 183, 410, 528, 402, 845, 220, 913, 123, 856, 246, 212, 505, 468, 316, 916, 218, 306, 652, 547, 175, 278, 673, 353, 747, 819, 308, 516, 407, 212, 972, 465, 340, 356, 622, 914, 294, 349, 296, 312, 264, 155, 223, 560, 697, 786, 149, 413, 331, 776, 975, 761, 694, 496, 963, 136, 765, 140, 741, 177, 669, 188, 660, 674, 808, 104, 978, 316, 142, 963, 728, 397, 930, 763, 406, 329, 197, 810, 852, 679, 443, 886, 563, 208, 602, 775, 214, 844, 868, 101, 463, 408, 608, 491, 421, 417, 397, 330, 672, 836, 678, 997, 665, 972, 173, 259, 860, 220, 652, 648, 385, 957, 213, 623, 889, 358, 994, 736, 678, 699, 891, 829, 862, 160, 408, 985, 423, 975, 600, 211, 221, 345, 768, 329, 667, 793, 806, 654, 610, 747, 428, 538, 477, 292, 528, 150, 462, 992, 976, 640, 607, 579, 458, 663, 945, 907, 900, 333, 428, 359, 572, 876, 151, 843, 651, 243, 380, 871, 132, 107, 753, 439, 267, 729, 490, 981, 655, 737, 970, 576, 270, 596, 547, 803, 163, 964, 401, 373, 674, 537, 412, 939, 488, 651, 331, 840, 519, 207, 852, 462, 319, 544, 590, 661, 110, 460, 691, 101, 971, 597, 913, 576, 881, 752, 960, 395, 215, 932, 340, 991, 182, 748, 484, 142, 805, 226, 512, 246, 285, 836, 155, 665, 324, 890, 462, 206, 500, 846, 805, 776, 249, 741, 180, 346, 611, 429, 225, 103, 921, 512, 120, 631, 710, 324, 787, 858, 341, 499, 883, 453, 735, 914, 132, 816, 407, 282, 827, 110, 208, 339, 895, 926, 392, 231, 501, 553, 877, 424, 782, 780, 128, 341, 472, 810, 199, 515, 559, 492, 785, 127, 881, 285, 413, 842, 456, 181, 670, 989, 347, 693, 626, 400, 228, 353, 923, 291, 977, 623, 223, 843, 557, 379, 573, 705, 859, 510, 255, 325, 633, 760, 774, 566, 637, 689, 960, 407, 351, 566, 238, 725, 957, 836, 331, 340, 535, 984, 375, 489, 124, 467, 283, 332, 120, 618, 120, 891, 917, 990, 210, 998, 867, 138, 823, 801, 449, 626, 831, 490, 789, 230, 621, 499, 272, 134, 869, 696, 787, 181, 951, 502, 834, 339, 464, 788, 231, 162, 178, 936, 271, 387, 180, 837, 282, 739, 181, 845, 674, 221, 777, 781, 834, 804, 751, 642, 436, 160, 265, 480, 787, 156, 633, 579, 696, 269, 793, 809, 624, 875, 479, 799, 443, 177, 616, 181, 306, 328, 404, 904, 789, 919, 474, 675, 908, 527, 649, 125, 582, 134, 553, 803, 965, 805, 459, 582, 218, 555, 373, 910, 532, 432, 792, 812, 682, 561, 948, 762, 283, 902, 342, 619, 605, 224, 631, 232, 531, 308, 425, 386, 482, 335, 769, 480, 762, 213, 720, 443, 959, 242, 207, 355, 654, 135, 382, 627, 274, 117, 456, 418, 496, 277, 243, 560, 551, 418, 736, 486, 769, 812, 461, 631, 648, 165, 251, 144, 780, 809, 615, 782, 639, 321, 267, 930, 415, 506, 295, 353, 263, 869, 281, 410, 199, 723, 528, 408, 971, 980, 290, 504, 567, 866, 628, 188, 876, 869, 299, 950, 640, 337, 553, 626, 547, 836, 706, 440, 260, 285, 315, 114, 368, 341, 209, 142, 789, 585, 938, 785, 868, 297, 474, 986, 995, 290, 631, 363, 881, 784, 503, 133, 393, 266, 193, 263, 396, 556, 968, 683, 619, 797, 891, 891, 424, 940, 491, 540, 355, 788, 467, 677, 431, 722, 578, 686, 374, 876, 318, 294, 783, 495, 165, 331, 293, 178, 303, 719, 858, 107, 978, 427, 176, 486, 198, 408, 966, 693, 866, 707, 675, 973, 423, 828, 857, 681, 142, 233, 215, 121, 539, 378, 483, 101, 221, 406, 795, 794, 281, 268, 457, 327, 405, 401, 726, 628, 289, 936, 899, 308, 904, 659, 561, 419, 346, 108, 701, 925, 290, 636, 113, 608, 518, 832, 695, 188, 939, 504, 277, 375, 156, 300, 459, 493, 439, 659, 515, 266, 101, 720, 222, 129, 453, 477, 981, 447, 105, 119, 961, 844, 750, 469, 317, 935, 705, 362, 852, 494, 519, 290, 918, 445, 695, 447, 874, 747, 387, 660, 246, 339, 421, 847, 230, 634, 158, 898, 1000, 768, 188, 299, 758, 794, 569, 792, 674, 723, 123, 316, 614, 231, 776, 410, 528, 806, 755, 435, 317, 317, 738, 718, 203, 427, 230, 277, 350, 654, 816, 898, 420, 316, 481, 720, 566, 985, 466, 310, 878, 667, 510, 608, 671, 519, 953, 926, 371, 958, 375, 526, 415, 322, 533, 549, 696, 223, 983, 927, 853, 145, 856, 846, 200, 838, 489, 534, 194, 717, 165, 435, 126, 967, 358, 955, 348, 648, 238, 579, 710, 377, 444, 902, 658, 588, 456, 629, 902, 611, 244, 843, 350, 939, 103, 114, 801, 816, 897, 128, 844, 582, 594, 250, 291, 867, 607, 841, 206, 341, 493, 510, 629, 378, 267, 464, 176, 580, 444, 905, 130, 699, 795, 219, 477, 470, 130, 545, 676, 542, 238, 139, 539, 858, 438, 459, 362, 860, 701, 272, 863, 279, 346, 867, 449, 117, 815, 399, 237, 358, 107, 868, 796, 840, 121, 297, 858, 673, 124, 103, 945, 541, 399, 215, 602, 295, 839, 383, 692, 292, 248, 645, 210, 408, 778, 383, 166, 910, 607, 411, 440, 386, 613, 745, 430, 847, 262, 977, 577, 820, 886, 187, 605, 147, 495, 414, 200, 511, 568, 916, 885, 875, 140, 674, 347, 467, 860, 461, 447, 985, 866, 104, 495, 590, 477, 339, 560, 394, 561, 407, 537, 121, 977, 881, 510, 319, 429, 452, 601, 769, 718, 136, 746, 127, 297, 566, 997, 909, 347, 834, 611, 532, 461, 603, 234, 125, 408, 167, 594, 149, 749, 764, 110, 394, 714, 217, 643, 109, 854, 351, 870, 730, 648, 654, 300, 802, 409, 274, 165, 685, 653, 581, 132, 591, 841, 892, 833, 809, 726, 638, 938, 767, 422, 975, 400, 577, 633, 463, 496, 114, 420, 310, 367, 447, 612, 269, 422, 156, 708, 612, 209, 208, 218, 103, 827, 299, 845, 786, 703, 703, 927, 430, 559, 611, 547, 471, 738, 856, 803, 526, 589, 713, 971, 737, 285, 492, 781, 645, 366, 637, 553, 985, 737, 201, 731, 993, 840, 161, 147, 534, 116, 676, 243, 292, 517, 523, 699, 793, 206, 441, 195, 253, 792, 273, 412, 243, 739, 923, 723, 461, 966, 105, 930, 551, 997, 587, 528, 232, 776, 880, 454, 121, 336, 908, 965, 102, 546, 771, 458, 947, 470, 955, 642, 291, 952, 176, 505, 896, 620, 907, 641, 121, 382, 271, 720, 474, 873, 296, 281, 152, 448, 682, 589, 202, 582, 446, 441, 525, 180, 849, 820, 549, 562, 994, 622, 249, 931, 894, 270, 655, 282, 343, 278, 491, 775, 258, 236, 699, 609, 655, 127, 606, 937, 513, 353, 736, 384, 532, 836, 819, 635, 752, 121, 428, 596, 805, 531, 635, 199, 491, 626, 297, 540, 362, 832, 547, 433, 745, 943, 742, 315, 895, 143, 894, 710, 257, 876, 944, 493, 646, 413, 537, 678, 512, 635, 306, 767, 568, 881, 730, 165, 620, 722, 325, 823, 495, 255, 658, 350, 298, 820, 479, 162, 210, 916, 587, 275, 950, 763, 540, 115, 541, 410, 745, 622, 436, 569, 642, 605, 920, 445, 483, 358, 422, 581, 985, 962, 938, 346, 875, 113, 372, 281, 979, 270, 478, 222, 422, 103, 588, 531, 863, 943, 985, 818, 593, 882, 541, 227, 171, 296, 794, 790, 500, 806, 885, 891, 987, 540, 323, 679, 722, 551, 182, 501, 813, 969, 839, 103, 384, 625, 993, 552, 672, 561, 923, 170, 304, 124, 993, 855, 408, 414, 655, 922, 346, 290, 587, 867, 597, 411, 981, 174, 440, 228, 214, 231, 618, 298, 532, 215, 231, 445, 623, 518, 361, 812, 552, 983, 957, 818, 769, 624, 219, 533, 713, 205, 995, 794, 385, 611, 556, 400, 350, 689, 713, 294, 284, 891, 348, 284, 234, 133, 423, 355, 587, 149, 606, 565, 376, 921, 583, 522, 316, 940, 564, 674, 744, 441, 977, 961, 656, 602, 406, 728, 763, 342, 855, 728, 422, 896, 194, 268, 907, 935, 490, 455, 549, 736, 343, 392, 557, 908, 768, 258, 667, 897, 357, 330, 974, 277, 410, 497, 971, 430, 138, 645, 849, 935, 447, 273, 957, 846, 274, 530, 138, 108, 111, 342, 235, 971, 568, 732, 935, 732, 261, 893, 902, 668, 894, 434, 137, 249, 933, 816, 487, 509, 573, 260, 314, 149, 141, 113, 641, 878, 375, 186, 665, 925, 187, 649, 883, 565, 369, 537, 636, 130, 935, 488, 290, 789, 142, 616, 224, 798, 686, 796, 132, 537, 949, 590, 509, 525, 291, 823, 967, 949, 699, 371, 793, 861, 622, 345, 187, 360, 116, 129, 523, 588, 699, 878, 552, 721, 594, 232, 170, 761, 670, 189, 506, 658, 110, 495, 341, 356, 551, 342, 206, 185, 598, 146, 646, 416, 243, 830, 948, 689, 708, 981, 376, 606, 432, 248, 203, 134, 824, 313, 857, 712, 509, 711, 382, 693, 539, 647, 329, 354, 604, 676, 690, 780, 495, 449, 541, 870, 709, 624, 412, 137, 847, 847, 208, 199, 227, 254, 683, 135, 626].\n",
      "Detected changepoints: [inf, 386, 162, inf, 165, inf, 624, 181, inf, inf, inf, 395, 129, inf, inf, 453, 383, inf, inf, 159, inf, inf, inf, 266, 226, inf, inf, inf, inf, inf, inf, inf, inf, 489, 334, 424, inf, 297, 383, 569, 178, inf, inf, inf, 239, 214, inf, 222, 304, inf, 300, 285, 225, 111, 237, 100, 165, 428, 969, 131, inf, inf, inf, 109, inf, inf, 106, inf, 504, inf, 142, 292, inf, inf, inf, 326, 126, 272, 229, inf, inf, 663, 221, 783, 235, inf, inf, inf, 354, 352, inf, inf, 476, 926, inf, 206, inf, inf, 513, inf, 221, 110, 144, inf, inf, inf, inf, inf, 107, 595, inf, inf, inf, 320, 610, 352, 115, 141, 131, 142, inf, inf, inf, 145, 234, 646, inf, 246, inf, 169, inf, 778, 111, inf, inf, 799, 143, inf, inf, 102, inf, inf, inf, 101, 195, inf, inf, inf, 274, inf, 398, 174, 346, inf, 111, 195, inf, 148, inf, inf, inf, 313, 566, inf, 133, 131, 153, inf, inf, 280, 109, inf, inf, inf, inf, 551, 526, 186, inf, inf, 269, 247, inf, inf, inf, 414, 114, inf, 117, 144, inf, inf, inf, 104, inf, inf, inf, 200, inf, 170, inf, 129, inf, inf, inf, inf, 877, 126, inf, inf, 203, 183, 100, 294, 237, 205, inf, 138, 597, inf, inf, 134, 344, inf, 252, 105, inf, 128, inf, inf, inf, inf, inf, 180, inf, inf, 321, 120, inf, 860, inf, inf, inf, inf, inf, inf, inf, inf, 352, 257, 112, 101, 503, inf, 649, inf, inf, 135, inf, inf, 417, 231, inf, inf, 308, inf, 368, 519, 659, inf, inf, inf, inf, inf, 150, 269, inf, inf, inf, 123, inf, inf, 300, 371, inf, inf, 288, 601, 402, 376, inf, inf, 201, inf, 121, 166, 260, inf, inf, 134, 367, inf, 348, inf, 283, inf, 248, 521, 856, 599, 518, inf, inf, 156, inf, 101, 773, inf, 116, 154, 108, inf, inf, inf, inf, inf, inf, 281, inf, inf, 277, inf, 136, 165, 105, inf, inf, 176, 298, inf, 336, 100, 284, inf, inf, inf, inf, inf, 152, 175, 678, inf, inf, inf, 212, inf, 138, inf, inf, 399, inf, inf, 198, inf, inf, inf, inf, inf, inf, inf, inf, 164, inf, inf, 121, 134, inf, 206, inf, 109, inf, inf, 355, inf, 694, 414, 578, 401, inf, 389, inf, 195, inf, 481, inf, 171, 363, 278, inf, inf, inf, inf, 418, inf, 191, inf, 776, 149, inf, 209, inf, inf, 653, 677, 691, 471, inf, inf, 269, 183, inf, inf, 363, inf, inf, inf, 373, inf, 366, inf, 718, 312, 387, inf, 788, 104, 214, inf, 313, inf, inf, inf, inf, 626, inf, 200, 373, inf, inf, 233, inf, 583, 133, inf, inf, 111, 220, inf, inf, inf, 410, inf, inf, 801, 311, inf, 348, 451, inf, inf, inf, inf, 116, 186, 508, 410, 138, 524, 133, 484, 552, 499, inf, inf, inf, 267, 240, inf, 128, inf, inf, inf, 905, 651, 250, inf, inf, 157, inf, 701, 625, inf, inf, 674, inf, 439, 154, inf, inf, 106, 423, 179, 152, 176, inf, 156, 106, inf, 513, inf, inf, 110, inf, 365, 235, inf, inf, inf, inf, inf, inf, inf, inf, 228, inf, 750, 353, 684, 117, inf, inf, inf, 225, inf, 114, 172, inf, 302, 321, 279, 889, inf, 259, inf, 333, 795, inf, inf, inf, 160, inf, 219, 419, inf, inf, 200, inf, inf, 522, 215, inf, 273, inf, inf, inf, inf, inf, 125, 145, inf, inf, 158, 139, 188, 442, inf, 179, 218, 112, inf, inf, 524, 173, 356, 273, inf, inf, inf, 228, 721, 137, 806, 192, inf, 546, inf, 508, inf, inf, inf, inf, 654, inf, inf, 195, 511, inf, inf, 652, 137, 183, 102, inf, inf, inf, 140, inf, 406, 405, 477, 102, 312, 154, 274, 532, 250, 230, inf, inf, 101, 434, 299, inf, inf, inf, 135, 854, 333, inf, 345, 300, inf, inf, 667, 383, 167, inf, 124, inf, inf, 204, inf, inf, 183, 216, inf, 791, 217, inf, 168, 621, 595, inf, inf, inf, inf, inf, inf, 123, 339, inf, 826, inf, inf, 159, inf, inf, 121, 190, 247, 353, 277, 554, 529, inf, 540, 355, inf, inf, 488, inf, inf, 288, 109, 443, 589, inf, inf, 313, 240, inf, inf, 619, inf, inf, 556, 292, 407, inf, inf, inf, 152, inf, 417, 144, inf, 110, 249, 200, 137, 249, inf, 181, 468, 240, 752, 399, inf, inf, 231, 403, 541, 160, inf, inf, inf, inf, 130, inf, inf, 568, 329, 527, 111, 162, 474, inf, 163, inf, 203, inf, inf, inf, 244, 638, inf, inf, inf, 268, 457, inf, inf, inf, inf, 861, 158, inf, 244, inf, inf, inf, inf, inf, 287, 125, inf, inf, 616, 238, inf, 124, 102, 108, 285, inf, inf, inf, 738, 780, inf, inf, 282, inf, 174, 363, 149, 886, 376, 371, inf, 109, 203, 697, 115, inf, 397, inf, inf, 140, inf, inf, inf, inf, inf, 211, 201, 436, inf, 280, inf, inf, 353, inf, inf, inf, inf, inf, inf, inf, inf, 539, 381, inf, 118, inf, 122, 159, 144, inf, 142, 124, 442, inf, inf, inf, 132, 173, inf, inf, inf, inf, inf, 286, inf, 310, 140, inf, inf, inf, inf, 201, inf, 336, 160, inf, 247, 117, inf, inf, inf, inf, 682, inf, inf, inf, inf, 155, 126, 158, inf, inf, inf, 229, 499, inf, inf, inf, 301, inf, 664, inf, 237, inf, 605, inf, 129, inf, 445, inf, inf, 800, inf, inf, 167, 175, 389, 848, inf, inf, 298, 694, inf, inf, 433, inf, 750, inf, inf, inf, inf, 110, 199, inf, inf, 141, inf, inf, inf, inf, 113, inf, 297, 140, inf, 494, inf, inf, inf, 366, 115, inf, 414, 817, 306, 325, inf, 259, 606, inf, 112, 228, 229, inf, inf, 764, inf, 244, 131, inf, 414, inf, inf, 210, inf, inf, 796, 461, inf, 556, 556, 383, inf, 138, inf, inf, inf, 102, 411, inf, 529, 253, inf, inf, 816, 277, inf, 262, inf, inf, 161, 367, 634, inf, 107, inf, inf, 495, 478, inf, 357, inf, inf, 161, 733, inf, 106, inf, 732, inf, inf, 361, 191, inf, 104, 176, inf, inf, inf, 114, inf, 118, inf, 150, 314, 178, 132, 108, inf, inf, 207, 185, inf, inf, 155, 401, inf, inf, inf, inf, 501, inf, 173, inf, 332, inf, inf, 341, inf, inf, inf, 644, 617, inf, inf, inf, inf, 136, inf, inf, inf, inf, 701, 129, inf, inf, 706, inf, 263, inf, inf, 352, 171, inf, 176, inf, 144, 103, 126, 128, 109, 114, 475, 753, inf, 416, 269, inf, inf, 208, 106, 106, 243, 165, inf, 211, inf, inf, inf, 215, inf, 247, inf, inf, 527, 582, 606, 291, inf, 230, inf, 290, inf, 153, 137, inf, inf, inf, inf, inf, inf, inf, inf, inf, inf, 333, 429, inf, 781, 186, 176, inf, 360, 321, inf, inf, 535, 191, inf, 454, 362, 248, 602, inf, inf, inf, inf, inf, inf, 144, 181, inf, 205, inf, inf, inf, 151, 330, 115, 353, inf, inf, inf, 112, inf, 211, 342, 117, 153, 100, 153, inf, inf, inf, inf, 493, inf, inf, inf, inf, inf, 280, inf, 166, inf, inf, inf, 436, 122, inf, 222, inf, inf, 305, 144, inf, 192, inf, 166, 383, 198, inf, 258, inf, 153, 744, 177, inf, inf, inf, 131, inf, inf, 282, 765, inf, 107, inf, inf, 150, inf, 116, inf, 865, inf, inf, 440, 461, inf, inf, inf, 378, inf, 191, inf, 121, inf, inf, 134, inf, inf, inf, inf, inf, 318, inf, 145, inf, inf, inf, 411, 398, inf, inf, inf, inf, inf, inf, inf, 112, 330, inf, 710, inf, inf, inf, inf, inf, inf, inf, 176, 606, inf, inf, inf, 527, inf, 166, 203, inf, 324, inf, 237, inf, 503, inf, inf, 433, 214, inf, 642, inf, 166, inf, 312, inf, 407, 416, inf, inf, 155, inf, inf, 593, 661, inf, inf, 134, inf, inf, 611, 207, 234, inf, inf, inf, 587, inf, inf, 128, 390, inf, inf, inf, inf, inf, inf, inf, inf, 232, 123, 643, inf, inf, inf, inf, inf, 213, inf, inf, inf, inf, 149, 100, 311, inf, inf, 172, inf, 385, 102, inf, 140, inf, inf, 315, inf, 127, 534, inf, 112, 160, 163, inf, 156, inf, 252, inf, inf, inf, 290, 212, 187, 181, 225, inf, inf, 317, 108, 183, inf, inf, inf, inf, inf, 448, inf, 162, inf, 201, inf, 159, inf, 149, inf, 119, 162, 351, 160, 210, 107, 129, 179, inf, inf, 286, inf, inf, inf, inf, inf, 720, 108, inf, 254, 162, 280, 240, inf, 318, inf, inf, 268, inf, inf, inf, inf, inf, 382, inf, inf, 173, inf, 152, 342, 156, inf, inf, 520, inf, 247, 306, inf, inf, inf, 246, 615, inf, 157, inf, inf, 180, inf, 165, 119, 297, inf, 162, 420, inf, 144, 199, 219, inf, 166, inf, inf, 677, 173, inf, 124, 110, inf, inf, inf, 357, 233, 135, 161, 172, inf, 137, 101, inf, 357, 323, inf, inf, 554, 590, inf, inf, inf, inf, 247, 232, inf, 625, inf, 164, inf, 103, inf, inf, inf, 112, inf, inf, inf, 245, inf, inf, 367, inf, 572, inf, inf, 259, inf, 507, 109, 154, inf, 283, 243, inf, inf, inf, 435, inf, inf, inf, inf, inf, 470, 129, 774, 173, 240, 159, inf, inf, inf, 107, inf, 672, 103, inf, 198, 140, 296, inf, 157, inf, inf, inf, 293, 233, 353, inf, 706, inf, inf, 170, 208, inf, inf, 106, inf, inf, 353, 357, inf, 522, inf, inf, 420, 224, 104, 115, 159, inf, 110, 203, inf, 316, 120, 253, 362, 165, inf, 190, inf, 860, inf, inf, inf, 463, 131, inf, inf, 149, 278, 183, inf, 177, inf, 662, inf, inf, 215, inf, inf, 361, inf, 163, 408, 590, inf, 107, inf, 216, inf, 728, 573, inf, inf, 345, 149, 403, inf, 113, 291, 395, inf, inf, inf, 301, 153, 324, inf, 235, inf, inf, 136, 476, 495, inf, 474, inf, inf, 104, inf, inf, 329, inf, inf, inf, inf, inf, 222, 101, inf, inf, inf, inf, 200, 624, 157, inf, inf, 254, 183, 451, 234, inf, 534, 588, 821, 281, inf, 234, inf, inf, inf, 115, inf, 612, inf, 102, 672, 185, 529, inf, inf, inf, inf, inf, 301, 154, 671, 728, inf, inf, 185, 266, 520, inf, 170, inf, inf, 339, 575, 210, inf, 602, 121, inf, inf, inf, 147, inf, 137, inf, 626, inf, 108, inf, 641, inf, inf, 188, 107, 135, 187, inf, 109, inf, 412, inf, 360, inf, inf, inf, 136, inf, inf, inf, inf, 144, 103, 809, 172, inf, 172, 653, inf, inf, inf, inf, 258, 122, 167, 335, 455, inf, inf, 205, 111, 372, 886, 433, inf, inf, 162, 750, inf, inf, 439, inf, inf, 226, 237, inf, 450, inf, inf, 289, inf, inf, 825, 552, inf, inf, inf, inf, 471, 569, inf, inf, inf, 128, 592, 154, inf, inf, 289, inf, 382, inf, inf, 839, inf, inf, 274, inf, 589, 137, 596, 159, inf, inf, inf, 389, inf, inf, inf, 157, inf, 572, inf, inf, 174, 196, inf, inf, inf, inf, inf, 316, 165, 165, inf, 258, 139, 275, inf, 172, 141, inf, 611, 199, 117, inf, 320, inf, 156, 118, 789, 167, inf, inf, inf, 379, 229, inf, inf, inf, 159, inf, 427, 446, inf, inf, inf, inf, inf, inf, 257, 195, 108, 234, 115, 144, inf, inf, 234, inf, 166, inf, inf, 146, inf, 174, inf, 257, 532, 138, inf, inf, inf, inf, 110, 379, inf, inf, 119, 328, inf, 460, 386, inf, inf, inf, inf, 614, 122, inf, inf, 315, inf, 905, inf, 409, 756, 161, 162, inf, 345, 426, inf, 377, inf, inf, inf, inf, 732, inf, 106, 452, 139, 371, inf, inf, inf, inf, 466, inf, 347, 412, inf, inf, inf, inf, inf, 537, 197, inf, inf, 199, inf, inf, inf, 366, 398, inf, inf, 390, inf, inf, 102, inf, 246, 475, inf, 378, inf, inf, inf, 337, inf, 116, inf, inf, 329, 146, 238, 315, 291, 248, inf, 459, 327, 805, 245, 197, 247, inf, inf, 343, inf, 128, 703, 407, 221, inf, inf, 101, 261, inf, inf, inf, 381, 116, 438, inf, inf, 208, 908, inf, 347, 163, 379, 390, 235, inf, 477, 228, 469, inf, inf, inf, 235, inf, inf, 158, 180, 207, inf, inf, inf, inf, 572, 259, 669, inf, 146, inf, inf, inf, inf, 108, inf, inf, 157, inf, 134, inf, 265, inf, 711, inf, 169, 182, 698, 699, inf, inf, 439, 113, 267, 595, 494, inf, 189, inf, 591, 168, 244, 942, 350, inf, inf, inf, 551, inf, 463, 136, 273, 602, 125, 707, 120, 760, 226, 105, 437, 641, inf, inf, inf, inf, 121, inf, 330, inf, 291, 347, 765, inf, inf, inf, inf, inf, inf, 556, inf, 966, 280, inf, inf, inf, inf, 261, inf, inf, 209, inf, inf, 113, inf, 244, 260, inf, 378, 127, inf, inf, 772, inf, inf, inf, inf, 158, 111, 100, 174, inf, inf, inf, 232, inf, inf, inf, 526, inf, 204, 111, 308, 218, 327, inf, inf, 312, inf, inf, 428, 335, inf, 159, inf, 181, 520, inf, inf, inf, inf, inf, 707, 213, inf, 483, inf, inf, 252, inf, inf, inf, inf, inf, inf, inf, inf, 380, 189, inf, 132, inf, 677, inf, 265, 177, inf, inf, inf, inf, 634, 789, 313, 103, inf, 172, inf, 438, 289, 129, 157, 278, inf, inf, inf, inf, 388, 258, inf, inf, 247, inf, inf, inf, inf, inf, 137, 186, 341, inf, inf, 200, 132, inf, 221, inf, inf, inf, inf, 342, 698, 232, inf, 146, inf, inf, inf, inf, inf, inf, inf, inf, 266, 508, inf, inf, 811, 307, 257, inf, 444, inf, inf, 257, 300, inf, inf, inf, 182, 191, inf, inf, 396, inf, 408, 122, 788, 172, 100, 789, 137, 688, inf, inf, inf, 189, 220, 451, 304, inf, 292, inf, 255, inf, inf, inf, inf, inf, inf, inf, 430, 487, 480, inf, 123, inf, inf, inf, 680, inf, inf, inf, 536, inf, 765, 316, 113, inf, inf, 330, 583, inf, 105, inf, 257, 197, 328, inf, 360, 502, inf, inf, 674, 156, 599, 225, inf, 538, inf, inf, 101, 177, inf, inf, 584, inf, inf, inf, 407, inf, 968, 118, 211, inf, inf, 397, inf, inf, inf, inf, inf, 137, 681, inf, inf, inf, 574, 277, 103, 151, 177, inf, 137, 154, inf, 137, inf, inf, 110, 123, 167, 126, 411, 283, 142, 184, 188, inf, inf, inf, 462, 272, 291, inf, 387, 129, inf, inf, 715, 409, inf, 819, 323, inf, inf, inf, 170, 103, 157, inf, inf, 276, 214, inf, inf, 400, 300, inf, 253, 187, inf, 370, 479, 340, inf, inf, 196, inf, 112, inf, inf, 158, inf, inf, 782, inf, 293, inf, 148, 156, 215, 800, 372, inf, inf, inf, inf, inf, 140, inf, inf, inf, inf, 215, inf, 118, inf, 440, inf, 183, inf, 300, 298, inf, 121, 291, inf, 589, inf, inf, inf, inf, inf, 172, inf, inf, inf, inf, inf, 279, 529, inf, 100, inf, inf, inf, 342, inf, 142, 118, inf, 292, 569, inf, 719, inf, 170, inf, 164, inf, 388, 545, 268, 165, 241, inf, 247, 912, inf, inf, 580, inf, inf, inf, 554, 201, 376, inf, inf, 330, inf, inf, 100, inf, 881, 107, inf, 750, 169, inf, inf, 137, inf, inf, inf, 491, inf, 104, 390, 676, inf, 171, inf, 241, inf, inf, inf, inf, inf, 661, inf, 363, 645, 580, inf, 489, 108, inf, 582, inf, 141, 503, 945, 128, inf, 206, inf, inf, 102, 613, inf, inf, 159, 414, 292, 230, inf, 100, inf, inf, 297, 654, inf, inf, inf, inf, 618, 125, 434, inf, 198, 165, inf, inf, inf, inf, inf, inf, inf, inf, 142, 263, inf, inf, 269, 212, 197, 193, inf, 210, inf, inf, inf, inf, 625, 412, 514, 220, 150, 163, 283, 121, inf, 102, inf, 104, inf, 184, 577, 851, inf, inf, 499, inf, inf, 445, inf, 130, inf, 294, 476, 146, inf, inf, 186, 361, inf, 142, 108, inf, inf, inf, inf, inf, 436, 133, inf, inf, 639, inf, 106, inf, inf, 123, inf, 163, inf, 552, inf, inf, inf, inf, inf, inf, 265, 107, 770, inf, inf, inf, 293, inf, 330, 694, inf, inf, inf, inf, inf, inf, inf, 103, inf, inf, inf, 267, 686, inf, inf, 290, inf, inf, 183, inf, 121, inf, 172, 174, 234, 260, 447, inf, 277, 524, inf, 276, 117, inf, 489, 204, inf, inf, 227, inf, inf, inf, 322, 327, 596, inf, inf, inf, inf, inf, inf, 101, inf, inf, 545, 134, 320, inf, 295, 137, inf, 258, inf, inf, 450, 232, 181, inf, 289, inf, 334, 377, inf, 274, 218, inf, inf, 158, 122, inf, inf, 289, inf, 531, inf, 179, inf, 192, inf, 355, inf, 681, 184, inf, 159, inf, inf, 774, inf, inf, inf, 220, inf, inf, 253, 150, inf, inf, inf, 279, 326, 136, inf, inf, inf, 295, inf, 219, inf, inf, inf, 291, 328, 248, inf, 100, 174, 358, inf, 316, inf, 122, 155, inf, 104, 422, 226, 640, inf, inf, inf, inf, inf, 140, inf, 325, inf, inf, 285, 152, inf, 189, 117, 299, 748, inf, inf, 177, inf, 221, 200, 380, inf, inf, 258, 268, 324, 240, inf, inf, 169, inf, 111, inf, inf, inf, inf, 290, 332, inf, 641, 170, 143, 217, 533, 365, inf, inf, inf, inf, 534, 300, inf, 964, inf, 406, inf, inf, 622, inf, inf, 222, inf, inf, inf, inf, inf, inf, inf, inf, 193, inf, 175, inf, inf, 622, inf, 141, inf, inf, 279, inf, 377, 499, 247, 127, inf, inf, inf, inf, inf, inf, 277, inf, 221, inf, 554, inf, 717, inf, 311, inf, inf, inf, 273, 143, inf, inf, 141, inf, 291, inf, inf, inf, 934, inf, 411, inf, inf, inf, inf, 752, 105, inf, 457, inf, inf, inf, inf, inf, 261, inf, inf, inf, inf, 114, inf, 647, inf, 470, 459, inf, 715, inf, 107, 302, inf, 195, 377, 201, 165, 198, inf, inf, 162, inf, inf, 319, inf, inf, 554, 185, 813, 428, inf, inf, 302, inf, 183, 383, inf, 296, 510, inf, 386, inf, inf, inf, inf, 601, inf, 169, 184, inf, inf, inf, inf, inf, 127, inf, 656, 124, inf, inf, inf, 127, inf, 173, inf, inf, inf, 332, 392, inf, inf, inf, 149, 124, 628, 115, 103, 417, 192, inf, inf, 113, 108, 385, 562, inf, inf, inf, inf, 591, 258, inf, inf, inf, inf, 592, inf, 218, inf, inf, 159, 467, inf, 383, inf, 275, inf, inf, inf, 146, inf, inf, 463, 102, 421, inf, inf, 733, inf, 203, inf, inf, inf, 315, inf, 337, 373, 242, 122, 485, inf, 483, inf, inf, 183, 171, inf, 105, inf, inf, inf, 572, 547, inf, 110, inf, 226, 108, 190, inf, 392, inf, 753, 178, inf, 427, inf, 259, inf, 130, inf, inf, 324, 305, 193, inf, inf, inf, inf, 108, inf, inf, 291, 140, 174, inf, inf, inf, inf, inf, 275, 367, inf, 611, 166, inf, 270, 115, 286, 193, inf, inf, inf, inf, inf, 233, inf, inf, inf, 104, 573, inf, inf, inf, 248, inf, inf, 866, inf, inf, inf, inf, 169, inf, inf, 151, 230, 286, inf, 171, inf, 120, 465, inf, 346, inf, inf, inf, 270, inf, inf, 149, 283, 116, inf, inf, inf, inf, inf, inf, 264, inf, inf, inf, inf, 155, 396, 137, inf, 243, 535, 218, inf, 200, 179, 674, inf, inf, inf, 595, inf, 515, 197, inf, inf, 810, inf, inf, inf, inf, 190, 100, inf, 174, 270, 451, 780, 352, 120, 148, 104, inf, inf, 180, 128, inf, inf, 212, inf, 100, 291, inf, inf, inf, inf, inf, inf, inf, inf, 290, 477, 435, 749, inf, 491, inf, 161, inf, inf, 180, 297, inf, 405, 207, inf, 167, inf, inf, inf, 203, 418, 159, inf, 128, 310, inf, inf, inf, 113, 120, inf, inf, inf, 123, 462, 460, inf, inf, 271, 261, inf, 312, 595, inf, 476, inf, 391, 120, 104, inf, inf, 219, 315, 191, 106, 400, 104, 416, inf, 152, inf, 280, inf, 577, 213, inf, 212, inf, inf, 254, inf, 498, 165, inf, inf, 327, 139, 182, inf, inf, inf, 228, inf, inf, inf, 241, 310, inf, inf, inf, 151, 388, 133, inf, 525, inf, inf, inf, inf, 170, 610, 115, inf, inf, 114, inf, 317, inf, inf, inf, 344, inf, 610, 399, inf, 243, inf, inf, inf, inf, inf, 189, 176, inf, 136, inf, 161, inf, 243, inf, 221, 297, 317, 148, 101, inf, inf, 231, inf, inf, inf, 143, inf, inf, inf, inf, 153, 150, inf, 124, inf, 139, inf, inf, 228, 118, 103, inf, 314, 385, inf, 186, 116, inf, 233, 504, inf, 501, 482, 665, inf, 326, inf, 835, 145, inf, inf, 469, inf, inf, 558, inf, inf, 322, 878, inf, inf, 284, 734, inf, 233, 295, 334, inf, inf, inf, inf, 228, 609, inf, 228, inf, 166, 142, 283, 187, inf, inf, 123, inf, inf, inf, inf, 187, 110, inf, inf, inf, inf, 129, 165, 416, 325, inf, 104, 246, inf, inf, inf, inf, 190, inf, 252, inf, inf, inf, 100, 345, 222, inf, 105, inf, inf, inf, 193, 715, 401, inf, 179, inf, inf, 421, inf, inf, inf, inf, inf, 161, inf, inf, 793, inf, inf, inf, 253, inf, inf, 108, 245, 120, 326, 651, 113, inf, 102, inf, inf, 243, 197, inf, 795, 164, 377, 527, 362, inf, inf, inf, inf, 573, inf, inf, inf, 250, inf, 348, inf, 106, inf, 448, inf, inf, inf, 242, inf, 124, 650, inf, 773, inf, inf, inf, 760, inf, inf, inf, inf, 142, 236, inf, 303, 240, inf, inf, inf, 223, 449, 275, 667, 370, 212, inf, inf, 341, 147, inf, 265, inf, 267, 106, inf, 177, inf, inf, 773, 775, inf, inf, 348, inf, 227, 440, 155, inf, inf, inf, 508, inf, 949, inf, inf, 117, 323, inf, 285, inf, 139, 493, inf, inf, inf, inf, 158, inf, inf, 566, inf, 728, 332, inf, 100, inf, 636, inf, 448, 277, inf, inf, 204, inf, 590, 158, 585, 203, inf, 247, 109, inf, inf, 154, 416, 296, 157, 161, 103, 116, 112, inf, 460, inf, 142, inf, 176, 900, 228, inf, 657, inf, inf, inf, 836, 160, inf, 487, inf, 142, inf, 883, inf, 139, inf, 265, inf, inf, inf, 104, 280, inf, 114, inf, 109, inf, inf, inf, 150, 134, inf, 121, inf, 183, inf, inf, 111, inf, inf, inf, 340, inf, inf, 435, 766, inf, inf, inf, inf, inf, 179, 188, 710, 100, inf, 274, 457, 203, 462, inf, inf, 258, inf, inf, inf, inf, inf, 131, 290, inf, 176, inf, 132, 245, 129, 532, inf, 398, 581, inf, inf, inf, inf, inf, inf, 424, 616, inf, 236, inf, 667, 268, 411, inf, 528, 331, inf, inf, 664, inf, 143, inf, inf, 295, inf, 434, inf, inf, 264, 258, inf, inf, inf, 371, inf, 137, 404, 381, 195, 698, inf, 182, 169, 313, inf, inf, 146, 320, inf, 304, 525, inf, 120, 289, inf, 146, 369, inf, 603, inf, inf, 280, inf, 514, 227, 195, inf, 387, 595, 213, 140, inf, 571, inf, inf, inf, 407, 100, 450, inf, 400, inf, inf, 130, inf, inf, 622, inf, 485, 864, inf, 289, 450, inf, 629, inf, inf, 190, inf, 500, inf, 159, inf, inf, 286, 584, 119, inf, 401, inf, inf, inf, 523, inf, inf, 175, 164, 162, inf, 233, 399, inf, 119, 536, 202, inf, 260, 810, 221, inf, 351, 178, 231, inf, inf, 138, inf, 117, 173, inf, 279, inf, 111, 272, 437, 127, inf, 172, inf, inf, 162, inf, inf, 144, inf, inf, inf, 565, inf, inf, inf, inf, inf, inf, inf, 106, 112, 448, inf, inf, inf, inf, inf, 357, inf, inf, 683, inf, 328, inf, 179, 223, inf, inf, inf, 499, inf, inf, 183, inf, 216, inf, inf, inf, 140, 526, 511, inf, 121, inf, inf, 406, 526, inf, 231, 660, 578, 470, inf, inf, 211, inf, inf, inf, inf, inf, 414, 127, 880, 424, 535, inf, 157, inf, 193, inf, inf, 644, inf, inf, inf, inf, inf, inf, 172, inf, 176, inf, 149, 220, inf, 113, inf, 310, inf, inf, inf, inf, inf, 703, inf, inf, inf, 740, 235, 369, 347, 299, 103, 146, 122, inf, inf, 292, 117, inf, 287, inf, inf, 298, 409, 191, inf, inf, 186, inf, 146, inf, inf, 481, 178, 431, 228, inf, 555, inf, inf, 158, 115, 258, 453, 115, inf, inf, 555, inf, 429, 394, 381, inf, 120, 379, inf, inf, inf, inf, inf, 596, inf, inf, 238, inf, inf, inf, inf, inf, 369, inf, 294, 102, 664, 226, inf, inf, 193, 209, 353, 359, inf, inf, 346, 977, 471, 627, 727, 639, inf, inf, inf, 332, 166, 218, 121, inf, inf, 229, 420, 353, inf, inf, 157, inf, 122, inf, inf, 212, inf, inf, inf, 206, 369, inf, 574, inf, 335, inf, 127, inf, inf, inf, inf, 658, inf, 102, inf, inf, inf, inf, 230, 350, inf, 112, 108, 104, 125, 409, 230, 125, 248, inf, inf, inf, 377, inf, inf, 118, 561, 108, 139, inf, 231, 160, 629, 212, 530, inf, 305, 245, inf, inf, inf, 118, inf, 615, 132, 257, 628, 340, 786, 331, inf, 453, inf, inf, inf, inf, inf, inf, inf, 266, inf, inf, 174, inf, 320, inf, inf, inf, inf, inf, inf, 103, inf, inf, inf, inf, inf, 257, 517, inf, inf, inf, inf, inf, inf, 114, inf, inf, inf, 235, 164, inf, inf, 112, 372, inf, inf, 412, 294, 121, inf, 299, inf, 405, inf, 164, 355, inf, 181, inf, inf, 167, inf, inf, 117, inf, 781, 147, inf, inf, 117, inf, 161, inf, inf, inf, 275, inf, 329, 857, 397, 724, 893, 176, 472, inf, inf, inf, inf, inf, 575, 236, inf, 280, 438, 135, 299, 157, inf, 188, inf, inf, 274, inf, 210, inf, inf, 100, 324, 261, 319, 426, inf, inf, 219, inf, inf, 586, 405, inf, 181, inf, inf, inf, 514, inf, 101, inf, inf, 515, inf, inf, 549, 145, 336, 164, 428, 627, 394, 529, 382, 233, 204, 689, inf, inf, 237, inf, inf, inf, 385, 678, inf, 510, 140, inf, 361, inf, 154, inf, inf, inf, 118, inf, inf, 511, 150, inf, inf, 522, inf, inf, 145, inf, 126, inf, inf, 856, 267, inf, 328, inf, inf, 117, 136, inf, inf, inf, inf, 113, inf, 350, inf, inf, 203, 670, 103, inf, 620, 179, 523, 135, 335, 103, 113, 126, inf, inf, 102, 576, 285, 497, inf, 139, inf, inf, 553, 186, 126, inf, inf, inf, inf, 134, 115, inf, 590, 204, inf, 401, inf, 837, 638, inf, 149, 620, 243, 318, 191, inf, inf, inf, 152, inf, 208, inf, 377, 518, inf, inf, 349, inf, 569, inf, 171, 129, inf, inf, inf, 783, 149, inf, 185, inf, inf, 153, inf, 168, 104, inf, inf, inf, 251, 251, 196, 136, inf, 467, inf, 219, inf, inf, inf, 164, inf, 634, 554, inf, 280, 141, inf, inf, 772, inf, inf, inf, 176, 328, 295, inf, 492, inf, 378, inf, 578, 278, inf, inf, inf, inf, 186, inf, 345, 108, 260, 261, 108, inf, 548, 229, inf, 271, inf, inf, 490, 454, inf, inf, 115, 240, inf, inf, 109, inf, inf, inf, inf, inf, inf, inf, inf, inf, inf, 734, inf, 195, 495, 109, inf, 238, 279, 425, inf, inf, 175, inf, 167, inf, inf, 311, inf, inf, 197, inf, 533, 133, inf, inf, inf, 384, 597, 663, inf, 245, inf, 353, inf, inf, inf, 362, 116, inf, 635, 202, inf, 510, 452, 762, inf, inf, inf, inf, 341, 568, 546, inf, inf, inf, 502, inf, 796, 126, 204, inf, 386, 158, 139, inf, inf, inf, inf, 323, 895, 164, inf, 200, 212, 658, inf, inf, 287, 306, inf, inf, 137, 126, 451, inf, inf, 235, inf, inf, inf, 675, 211, 355, inf, inf, 140, inf, inf, inf, inf, inf, 272, inf, inf, 205, inf, inf, inf, inf, 174, inf, 531, inf, 130, inf, inf, 449, inf, inf, 219, inf, 350, inf, inf, inf, 387, 538, 102, inf, 170, inf, inf, inf, 439, inf, inf, inf, inf, inf, inf, inf, 388, inf, inf, inf, 721, 292, inf, inf, inf, inf, 105, 202, 106, 282, inf, inf, 506, 152, 146, inf, 286, inf, inf, inf, inf, inf, inf, inf, inf, 157, 219, inf, 158, 223, 250, 173, 187, 490, inf, inf, 145, 144, inf, inf, inf, inf, 261, 844, 314, 154, inf, 292, 212, inf, inf, 311, 479, inf, 589, 185, 211, 311, inf, 458, inf, inf, inf, inf, inf, 185, inf, inf, inf, 163, inf, inf, inf, 108, inf, inf, inf, inf, 215, inf, inf, 293, inf, 143, inf, inf, 319, inf, 763, 590, 377, inf, inf, inf, inf, inf, inf, inf, 197, inf, inf, 135, 224, 188, inf, 501, inf, inf, 127, inf, 100, inf, inf, 530, inf, 500, inf, inf, 109, 102, 140, inf, 455, inf, inf, 278, 375, inf, 101, 365, inf, inf, 460, inf, 199, 412, inf, inf, 128, inf, inf, inf, inf, 597, inf, 736, 175, inf, 127, 112, inf, 179, inf, inf, inf, 431, inf, inf, 333, inf, 798, 460, inf, 230, 232, inf, 312, 799, 178, inf, 217, 127, 119, 586, inf, inf, 119, 166, 111, inf, 332, inf, 472, inf, inf, 134, inf, 141, 122, 192, 180, 423, 310, 128, 162, 318, inf, inf, inf, 180, 326, 274, inf, 400, inf, 120, 285, inf, inf, inf, inf, inf, 295, 157, inf, inf, 310, 117, 310, inf, 394, inf, 432, inf, inf, inf, 239, 112, inf, inf, inf, 132, 106, inf, inf, 274, 533, inf, inf, inf, inf, inf, inf, inf, inf, 354, 506, 122, 351, inf, inf, 494, inf, 683, 622, 168, 184, 128, inf, inf, 133, 284, inf, 344, 681, 153, inf, inf, 599, 366, 395, 566, 526, inf, inf, inf, inf, 231, inf, 538, inf, inf, 286, 360, inf, 558, 544, 143, 142, inf, inf, 136, 231, 333, 300, inf, inf, 120, inf, 470, 857, 118, 193, inf, inf, inf, 820, inf, inf, 299, 104, 583, inf, 255, 221, inf, inf, inf, 174, 210, inf, 476, 241, 194, 311, inf, 119, 215, 747, 233, 126, 213, inf, 163, inf, inf, inf, inf, 107, inf, inf, inf, 449, 283, 275, inf, inf, 116, inf, 507, 206, 136, inf, inf, 130, inf, inf, 276, inf, 465, inf, inf, 103, inf, 315, 161, 653, inf, inf, inf, inf, 114, 631, inf, inf, 394, inf, 162, 194, inf, inf, 178, inf, inf, inf, 110, inf, inf, inf, 205, inf, inf, 290, inf, 498, 102, inf, inf, 147, 115, 299, 192, inf, 142, inf, 145, 403, inf, inf, 190, 260, 410, inf, 217, inf, inf, inf, inf, 278, 923, 407, inf, inf, 393, inf, inf, 269, 257, inf, 343, 330, 164, inf, 104, inf, 131, inf, 108, 139, 129, inf, inf, inf, inf, inf, 169, 194, inf, 125, inf, inf, 169, 735, inf, inf, 264, inf, 114, 125, 260, 467, 108, 672, 157, 815, inf, 110, inf, inf, 142, 506, 627, 123, 104, 162, 520, inf, inf, 836, inf, inf, inf, inf, 277, 223, 232, 160, inf, inf, inf, 162, inf, 123, 227, 424, inf, 235, inf, 123, 252, 136, 199, inf, inf, inf, inf, inf, 554, inf, 222, inf, 569, 206, 349, inf, 555, 155, inf, 622, 207, 239, 486, inf, inf, 209, inf, inf, inf, 157, 678, inf, inf, inf, inf, inf, inf, inf, inf, 231, 237, inf, inf, inf, 478, inf, inf, 152, inf, 109, 272, 138, 327, inf, 379, 851, 405, 170, inf, inf, 127, inf, inf, inf, 667, inf, inf, 222, inf, inf, 299, inf, inf, 227, 360, 204, inf, inf, inf, inf, inf, 203, 761, 403, 685, 119, inf, inf, inf, inf, inf, 250, 470, 305, inf, inf, inf, inf, inf, inf, 101, 549, 290, inf, inf, 273, 273, inf, inf, 472, inf, inf, inf, inf, 131, 651, inf, 280, inf, 945, 135, inf, 354, 377, 183, 192, inf, 685, 610, 175, 225, inf, inf, inf, inf, 128, inf, 452, inf, 138, 211, 337, inf, inf, inf, 353, inf, 270, 210, inf, inf, 237, inf, 732, 397, inf, 176, 309, inf, inf, inf, inf, 258, inf, inf, inf, inf, 189, inf, 528, 551, 168, 115, 461, 633, 172, 492, inf, 505, 244, inf, inf, 175, 181, 329, 341, 328, inf, 753, 676, 145, inf, 225, inf, inf, 872, 404, 535, 899, 167, 280, 193, inf, inf, inf, 177, 145, inf, 388, inf, inf, 262, inf, inf, 137, 333, inf, inf, inf, 360, inf, 127, 667, 308, 494, 142, inf, 494, inf, 142, 287, 370, 347, inf, inf, inf, inf, 469, inf, inf, 215, 265, inf, 194, inf, inf, inf, inf, 228, inf, 300, inf, inf, 182, inf, 102, 362, 268, 198, inf, 111, 355, inf, 333, inf, 113, inf, inf, 421, inf, inf, 409, 249, inf, 105, 771, 848, 202, 168, 205, inf, 473, 305, inf, 130, inf, inf, inf, inf, 413, 303, 409, 180, 322, 361, 122, inf, 319, 326, 344, 606, inf, inf, inf, inf, 403, 241, inf, inf, 764, 354, 125, 316, 345, 122, inf, 811, 209, 777, 343, 968, 632, 201, 103, 927, inf, inf, 592, inf, 605, inf, 734, inf, 133, inf, 216, 907, inf, inf, 308, inf, inf, inf, inf, inf, 367, inf, inf, 303, 122, inf, inf, 324, inf, inf, 160, inf, 620, inf, 222, 445, inf, inf, 352, inf, 205, 227, 204, inf, 179, inf, 913, 199, inf, 185, inf, inf, 191, 262, 496, inf, 169, 873, 823, inf, inf, inf, 193, 470, 147, inf, inf, 202, 206, 113, inf, inf, inf, inf, 244, inf, 159, inf, 816, inf, inf, inf, inf, inf, 121, 113, 336, 440, 125, inf, inf, 133, 276, inf, inf, inf, 184, 425, inf, inf, inf, 514, inf, inf, inf, 371, 223, inf, 431, inf, inf, 430, inf, inf, 144, inf, inf, inf, 632, inf, 187, inf, inf, inf, 321, inf, inf, 103, 122, 643, 129, inf, inf, 111, 554, inf, inf, 493, inf, inf, inf, inf, 152, inf, 473, 152, 256, inf, 205, inf, inf, 209, inf, 175, inf, 106, 102, 230, inf, inf, 379, inf, inf, inf, inf, inf, 271, 496, inf, inf, 167, 285, 153, inf, inf, 433, 107, inf, 324, 552, 321, inf, 130, inf, 509, 207, inf, 160, inf, inf, 146, inf, inf, 242, inf, inf, inf, 259, 749, inf, 231, inf, 493, 781, inf, inf, 103, inf, 615, 200, inf, 119, 152, inf, inf, inf, inf, 128, inf, 243, 221, inf, inf, 253, inf, 119, 217, 164, 563, 124, 121, 427, inf, inf, 823, 288, 164, inf, inf, 392, inf, inf, 115, inf, inf, 135, 209, inf, 233, inf, 482, inf, 458, inf, inf, inf, 198, inf, inf, 102, inf, 387, inf, 125, 119, 446, 200, inf, inf, inf, 125, inf, 101, inf, inf, 216, 337, inf, inf, inf, inf, 248, inf, 494, inf, 285, 226, 427, 114, inf, 173, 101, 410, inf, 250, inf, inf, inf, 166, 131, inf, 463, 107, inf, 123, 266, 467, inf, 126, inf, inf, 180, inf, inf, 126, 338, inf, inf, inf, 474, inf, inf, inf, inf, inf, inf, inf, 617, 238, inf, inf, 829, inf, 336, 187, 290, 300, inf, 748, 460, 149, 185, 146, inf, inf, 461, 753, 636, inf, 505, inf, inf, inf, 283, 503, inf, inf, inf, inf, inf, inf, 190, inf, inf, inf, inf, 299, inf, inf, inf, 298, inf, inf, inf, 181, inf, 224, inf, inf, 860, inf, inf, 220, inf, 582, 158, inf, 514, 751, 115, inf, inf, 172, 120, inf, inf, inf, 195, 108, 145, 155, 246, 727, 715, inf, inf, 254, inf, inf, inf, 445, inf, inf, 258, inf, inf, inf, 461, inf, 145, 174, 164, 183, inf, 321, inf, 134, inf, 493, inf, inf, inf, inf, inf, 472, inf, 135, inf, inf, 125, 103, inf, inf, 135, 469, 274, inf, inf, inf, inf, inf, inf, inf, inf, inf, 122, 403, inf, inf, 327, inf, 100, 596, 224, inf, 364, inf, inf, 108, inf, inf, 295, inf, 340, inf, 436, 147, 222, inf, 117, 342, 870, 255, 199, 145, 147, inf, inf, 290, inf, 105, inf, inf, inf, inf, 107, 289, 745, inf, inf, inf, 497, 252, inf, 337, inf, inf, inf, inf, 616, inf, inf, 206, inf, inf, 655, 215, 591, 192, 369, inf, inf, inf, 208, inf, inf, inf, 303, 157, inf, inf, 419, 153, 391, 164, inf, 488, inf, inf, 102, inf, 328, inf, 858, inf, 191, 344, inf, 221, 368, 525, inf, inf, 382, 158, 294, 805, inf, 584, 201, 223, 187, 281, 551, inf, inf, 322, inf, 515, inf, 274, 538, 145, inf, inf, inf, 719, inf, 269, 103, inf, 705, inf, 181, inf, inf, 639, 355, inf, inf, inf, inf, 172, inf, inf, inf, inf, 115, inf, inf, 112, inf, inf, inf, inf, 438, inf, inf, 334, inf, 971, inf, 518, inf, inf, inf, 127, inf, inf, 441, 132, inf, 589, inf, 106, 413, inf, inf, 675, 422, 327, inf, 603, inf, inf, 821, 547, inf, inf, inf, 234, inf, inf, 178, 110, 524, 102, 438, inf, inf, 534, 354, inf, inf, inf, 316, 825, inf, 352, inf, inf, 128, inf, inf, inf, 620, 310, inf, inf, inf, 159, 107, inf, inf, 157, 385, inf, inf, 156, 227, 593, 613, inf, inf, 515, inf, inf, inf, inf, 326, inf, inf, inf, inf, inf, 113, 243, inf, inf, 542, 590, 525, 138, inf, inf, 259, inf, 370, 135, 226, inf, inf, 321, 181, inf, inf, inf, 642, 115, 330, inf, 556, inf, inf, 125, 221, inf, 155, inf, inf, inf, 120, 276, inf, inf, 186, 238, inf, inf, 273, inf, 118, inf, 310, 656, inf, 227, 275, 374, 528, inf, inf, inf, 932, inf, 246, inf, inf, inf, 288, 117, inf, 673, 605, inf, 236, inf, inf, inf, 106, 289, 246, 213, 116, 437, inf, 140, inf, inf, inf, inf, 949, inf, 192, 116, inf, 378, 295, inf, inf, inf, 164, 188, 619, 463, 167, inf, 109, 374, inf, inf, 637, inf, inf, 311, 103, 185, 109, inf, 224, inf, 305, 358, inf, 471, inf, inf, 211, inf, inf, inf, 467, 121, 127, 111, 143, inf, inf, inf, 161, inf, inf, inf, inf, 107, 294, inf, inf, 690, inf, 330, 166, inf, inf, inf, inf, 884, 157, inf, inf, 177, inf, 570, inf, inf, inf, inf, 103, inf, inf, inf, 108, 232, inf, 184, inf, inf, 405, inf, 121, 733, 154, 655, inf, 419, inf, 326, inf, 200, inf, 158, inf, inf, inf, 164, 260, 123, inf, inf, inf, inf, 164, 122, 202, inf, inf, inf, inf, inf, inf, inf, 202, 246, inf, inf, 117, 162, inf, 270, inf, 608, 110, 230, inf, inf, 107, inf, inf, 345, 281, inf, inf, 128, inf, 101, 402, 162, 157, inf, 540, 695, 136, 180, 267, 409, inf, 345, inf, 125, inf, 111, 737, 377, 292, 122, inf, inf, 207, 105, inf, 403, 136, 306, inf, inf, inf, 478, 368, 103, inf, inf, 499, inf, inf, inf, inf, inf, 149, 194, 193, inf, 113, 244, 422, inf, 379, inf, 207, inf, 103, 223, inf, inf, 340, inf, inf, 169, 269, 115, inf, inf, inf, 319, 116, inf, 295, inf, 308, inf, inf, 110, inf, 158, inf, 401, inf, 116, 162, inf, inf, 107, 208, 383, 167, inf, inf, inf, inf, 221, 743, inf, 190, inf, inf, inf, 116, inf, 205, 170, 114, 229, inf, inf, 291, 129, 133, inf, 278, 219, 440, 185, inf, 665, 356, 366, inf, inf, 525, inf, 212, inf, 324, 131, 727, inf, 769, 187, 114, inf, inf, inf, 827, inf, inf, inf, 658, 302, inf, inf, inf, inf, 580, 110, inf, 168, 171, inf, inf, inf, 155, 110, 254, 135, inf, 260, inf, inf, 355, inf, inf, inf, inf, inf, 197, inf, inf, 109, 329, inf, 159, inf, inf, inf, 302, 233, 234, 815, 381, 321, 806, inf, 227, inf, inf, inf, 118, inf, 138, inf, 153, inf, inf, 155, inf, 727, 520, 514, inf, 355, inf, inf, inf, inf, 403, 362, 321, inf, inf, 149, 102, inf, inf, 346, inf, inf, inf, 481, 112, 177, inf, inf, 516, inf, inf, inf, 367, 240, 111, inf, 362, 495, 101, 149, 142, 214, 110, 119, 104, inf, inf, 487, 501, 170, inf, inf, 111, inf, inf, 348, 233, 466, inf, 202, 198, 111, inf, inf, inf, inf, 337, inf, 365, inf, 383, 705, 112, inf, 129, inf, 133, inf, 652, 222, 240, inf, 435, 234, inf, inf, inf, 474, inf, 128, inf, 288, inf, inf, 798, 155, inf, inf, 348, inf, inf, 224, 538, 594, 212, inf, 383, 151, inf, 155, inf, 150, inf, inf, inf, inf, 108, 433, 250, 121, 362, 626, 678, inf, inf, 680, inf, 490, inf, 669, inf, 164, inf, inf, 307, inf, inf, 199, 138, inf, 127, inf, 226, 128, inf, 214, inf, inf, 147, 273, inf, 120, inf, inf, 165, 202, 663, 429, inf, inf, inf, 321, 614, 133, inf, inf, 308, inf, 262, 529, inf, inf, inf, 356, 113, inf, inf, 286, 301, 219, inf, 495, 116, 148, inf, inf, 167, inf, inf, 552, 643, 102, inf, inf, inf, 785, inf, 491, inf, 486, inf, 167, 678, 191, inf, inf, 582, inf, 155, inf, 271, inf, inf, inf, inf, inf, 150, inf, inf, inf, inf, 891, 301, 254, 333, 141, inf, inf, inf, inf, 382, inf, inf, 189, 153, 243, inf, 161, inf, inf, 288, inf, 659, inf, 254, 234, inf, 234, inf, 158, 375, inf, 107, inf, inf, 116, 353, inf, inf, 197, inf, 368, 573, inf, inf, 119, 138, inf, inf, 354, inf, 340, inf, inf, 226, inf, inf, inf, 469, inf, inf, 350, inf, inf, inf, 234, 454, 197, 115, inf, inf, inf, 167, 157, inf, 328, 169, 789, 245, 111, inf, inf, inf, 403, inf, 222, inf, inf, inf, inf, 101, inf, 382, inf, 427, inf, 407, inf, 138, 368, inf, 522, 185, 159, inf, inf, 164, 497, 294, inf, 107, inf, 288, 164, 386, 330, 174, 489, 123, 577, inf, 136, 110, inf, inf, 463, inf, inf, inf, inf, 526, inf, inf, 460, 136, inf, inf, 271, inf, 313, inf, inf, 309, inf, 385, inf, inf, 474, inf, 209, inf, 569, inf, 218, 148, 371, inf, inf, inf, inf, inf, inf, inf, 268, inf, inf, inf, inf, 319, inf, 378, 433, inf, inf, 288, inf, inf, inf, 572, 360, 805, 268, inf, inf, 183, 128, inf, 330, inf, 614, inf, 318, inf, 105, inf, 624, inf, 377, 168, inf, inf, inf, 380, 431, 130, inf, 503, inf, 547, inf, 105, inf, inf, 320, inf, inf, 198, inf, inf, 765, 306, 104, 471, 544, 157, inf, inf, 679, inf, 307, 124, 343, inf, 335, 549, inf, inf, inf, 328, inf, inf, 118, 207, 141, inf, inf, 231, inf, 256, inf, 127, inf, 570, inf, inf, 694, 158, inf, inf, inf, 145, 574, 135, 286, 124, 329, 259, inf, inf, 783, 227, inf, inf, inf, inf, inf, inf, inf, 122, 414, 450, inf, inf, 377, 154, inf, 506, inf, inf, inf, inf, 134, inf, 418, 190, 175, inf, inf, inf, 406, inf, inf, 342, inf, 110, 368, inf, 163, 560, inf, inf, 211, inf, inf, 130, 564, inf, 419, 141, inf, inf, inf, 174, 104, inf, inf, 355, 173, inf, 253, 497, inf, 272, inf, inf, inf, 649, inf, inf, inf, inf, 216, 164, inf, inf, 121, inf, inf, 153, 537, 178, 193, inf, inf, 136, inf, 142, inf, inf, inf, inf, 178, inf, inf, inf, inf, inf, 555, 234, inf, inf, 275, inf, inf, 382, 122, inf, 230, 241, inf, 576, 642, 213, inf, inf, 231, 142, inf, inf, 334, inf, 199, inf, 273, inf, inf, 151, 203, inf, 176, 389, inf, inf, 441, 210, 341, inf, 108, inf, 554, inf, 630, inf, inf, 548, 107, inf, 153, inf, inf, 193, 103, inf, inf, 266, 114, 239, 512, inf, 655, 346, inf, inf, 178, inf, inf, inf, inf, inf, inf, 378, 129, inf, 624, inf, inf, inf, 281, 366, inf, inf, inf, 298, inf, inf, inf, inf, 113, 514, inf, inf, inf, inf, 246, 203, 114, 163, 126, 268, 404, inf, 467, 189, inf, inf, inf, 141, 639, inf, inf, 396, 179, inf, inf, inf, 409, 303, 570, inf, 135, inf, 393, inf, 148, 406, inf, 361, inf, 116, inf, 157, 335, 247, 302, inf, 110, inf, inf, 490, inf, 237, 168, 158, inf, 284, inf, 418, 304, inf, inf, 368, inf, 370, 227, 926, inf, 334, 138, 644, inf, 139, inf, inf, 246, inf, inf, 119, inf, inf, inf, 168, inf, inf, 439, 261, 317, inf, inf, 177, 298, inf, 538, inf, 100, inf, 319, inf, 148, 624, 239, inf, inf, inf, 103, 681, 121, inf, 400, inf, 226, 194, inf, inf, inf, inf, 337, 575, inf, inf, 379, inf, 204, 189, inf, 262, inf, inf, 335, 123, inf, 100, 367, inf, 122, inf, inf, inf, 133, 773, inf, inf, inf, 122, inf, 161, 121, 341, 445, inf, 120, 251, inf, 268, 617, inf, inf, 102, inf, inf, 144, inf, 501, 230, 389, 281, 242, 289, inf, 127, inf, 829, inf, inf, 102, inf, 180, inf, 144, inf, 125, inf, inf, inf, 233, inf, inf, 521, inf, inf, inf, 154, 404, 101, inf, 341, inf, 386, 104, inf, 422, 375, 484, inf, 455, 255, inf, inf, 266, 872, inf, 391, inf, 275, 366, 100, 290, inf, inf, 242, 701, inf, 203, 574, 104, 175, inf, 561, 391, 171, inf, 173, inf, 636, inf, 299, 540, 121, inf, inf, 182, inf, 472, inf, 130, 120, 749, inf, inf, inf, inf, 420, 558, inf, inf, inf, 453, inf, inf, inf, inf, inf, 123, inf, 336, inf, 176, 262, 491, inf, 151, 507, 298, inf, 322, 631, 120, 120, 333, 633, inf, inf, inf, 178, 546, 527, 583, inf, inf, 371, 427, inf, 247, 139, inf, inf, inf, inf, 293, 766, 213, 100, 202, 101, 542, 164, 100, 632, inf, inf, inf, inf, 165, 619, 237, 844, inf, 153, 698, inf, 814, 216, inf, 683, inf, inf, 217, inf, inf, inf, inf, 210, 690, inf, inf, 109, inf, inf, inf, 112, inf, inf, inf, inf, inf, 137, 522, 393, 143, 127, 600, 443, inf, inf, 337, 175, 170, inf, inf, inf, inf, 508, 495, 480, inf, 251, 176, inf, 116, inf, 103, 276, 550, inf, inf, 575, inf, 688, 673, 538, inf, 100, 204, inf, inf, 213, inf, inf, inf, 436, 650, inf, 689, inf, 123, inf, 161, inf, 366, 292, inf, 176, 121, 735, inf, inf, inf, 279, 577, 270, 287, inf, 426, inf, 339, inf, 600, inf, inf, 365, inf, 256, inf, 208, 111, inf, 170, inf, inf, inf, inf, inf, 117, 389, 179, 302, inf, 106, 895, inf, 102, inf, 331, inf, inf, 266, 313, inf, inf, 195, inf, inf, 241, inf, 228, inf, inf, 102, 430, inf, 661, inf, 114, inf, inf, 318, 515, 475, 876, inf, 261, 368, 579, inf, inf, 149, 237, inf, 202, inf, 204, inf, 466, inf, 109, 368, inf, 231, inf, inf, inf, inf, 599, inf, inf, inf, 111, inf, 155, inf, 324, inf, 146, 235, inf, 572, 227, inf, inf, inf, inf, inf, inf, 228, inf, 109, 359, inf, 354, 147, 446, 641, 129, inf, 524, 692, inf, 295, 354, inf, inf, inf, 549, inf, inf, 117, 556, 262, 624, 274, inf, inf, 176, inf, 139, 197, 686, inf, 516, 125, 186, 516, inf, inf, inf, 652, 337, 228, 361, inf, 538, 422, inf, 471, inf, inf, inf, inf, inf, 573, 253, inf, inf, inf, 299, 398, 128, 114, inf, 160, 200, 312, 528, 128, inf, 341, 468, 526, inf, inf, inf, 477, 124, 458, 439, 781, 426, 141, inf, inf, inf, inf, inf, inf, 137, 717, inf, 244, inf, inf, inf, inf, inf, inf, 766, inf, inf, inf, 213, 164, 156, 156, 937, 552, inf, inf, inf, inf, 450, 165, inf, inf, 569, inf, 128, 295, inf, inf, 129, inf, 479, inf, inf, 488, 382, 118, inf, 337, 444, inf, 116, inf, 376, 334, inf, inf, inf, 734, inf, 111, 461, inf, 669, inf, inf, inf, inf, inf, inf, inf, inf, 271, 147, 142, 425, inf, 186, 110, 136, inf, 419, inf, 579, inf, 239, inf, 318, 374, 167, inf, 283, 263, inf, inf, inf, inf, 168, inf, 354, 689, inf, 100, inf, inf, 211, 137, 219, inf, inf, inf, inf, 229, inf, 535, 367, inf, inf, 183, 236, 198, 146, 113, 374, inf, inf, inf, inf, inf, 151, 104, 388, inf, inf, 176, inf, 601, inf, inf, inf, 259, inf, inf, 242, 107, inf, inf, 170, inf, 484, 514, inf, 393, inf, inf, 195, inf, inf, inf, inf, inf, 392, inf, inf, inf, inf, inf, 593, inf, inf, inf, 116, inf, inf, 503, inf, 256, 113, inf, 214, 310, inf, 595, inf, 319, 441, 176, inf, inf, 137, 110, 101, inf, 819, inf, 177, 477, inf, inf, inf, inf, inf, inf, inf, 525, inf, inf, inf, inf, 358, 216, 130, inf, 379, 466, inf, 200, inf, inf, 160, inf, 197, 203, 271, 156, 405, 240, inf, 256, 113, inf, 460, inf, 425, inf, 107, 406, inf, 522, inf, inf, inf, 343, inf, 191, 338, inf, inf, inf, 345, 202, 110, inf, inf, inf, 169, 243, 236, inf, 227, inf, 130, 104, 330, 633, 270, 332, 143, inf, 352, inf, 101, 353, inf, inf, 234, inf, inf, inf, inf, inf, inf, inf, inf, inf, 288, inf, inf, 386, 111, inf, 443, 106, inf, inf, 632, 148, 436, 171, 231, 374, 485, inf, 224, inf, 138, inf, 121, inf, inf, inf, inf, 165, inf, 660, 168, 904, inf, 620, 110, 233, inf, inf, inf, inf, 147, inf, 135, inf, inf, 311, 790, 147, 177, inf, inf, inf, inf, inf, 370, 681, inf, inf, inf, inf, 303, 117, 299, inf, inf, 604, inf, 555, inf, inf, 304, inf, 513, 341, 140, inf, 496, 267, 581, 181, inf, 547, 369, 742, 107, 139, 210, inf, inf, 186, 178, inf, inf, inf, inf, 450, 175, inf, 505, inf, 430, inf, 336, 224, 252, inf, inf, inf, inf, inf, 377, 226, 582, 206, inf, inf, inf, inf, 137, 166, inf, inf, 562, 368, 233, 353, inf, 212, 533, 475, inf, 106, 110, inf, 309, 236, inf, 412, 296, inf, 241, 480, inf, inf, inf, 448, inf, inf, 224, 414, inf, 414, inf, inf, 467, 849, 157, inf, 199, 185, inf, inf, 577, inf, inf, inf, inf, inf, 290, 327, inf, inf, inf, inf, inf, 252, 202, inf, inf, 157, 613, inf, inf, 669, inf, 496, inf, 721, inf, inf, 353, inf, 116, inf, 222, 517, 233, 488, 405, 369, inf, 128, 851, 176, inf, 115, inf, 225, 856, 526, inf, inf, 364, inf, 114, inf, 328, 122, inf, inf, 254, inf, 438, inf, inf, 312, 319, 122, 157, inf, inf, 399, 233, 125, 704, 102, inf, inf, inf, inf, 369, inf, 248, inf, 104, 312, 104, inf, 100, inf, 145, inf, inf, inf, 355, inf, 204, inf, inf, 132, inf, inf, inf, inf, inf, 940, 226, 134, 181, 110, inf, inf, inf, 282, 205, 108, inf, inf, 280, inf, inf, inf, 222, inf, 110, 146, 399, inf, inf, inf, inf, inf, inf, inf, 110, 363, inf, inf, inf, 142, inf, 531, inf, 115, 119, inf, 222, 108, inf, inf, 260, 167, 141, inf, 405, inf, 277, inf, inf, 167, 233, inf, inf, 136, inf, inf, inf, 614, inf, inf, 397, 137, inf, inf, inf, 402, inf, inf, inf, inf, 122, 598, 133, inf, 141, 634, 155, 216, inf, 711, 287, inf, inf, inf, inf, 194, inf, 112, 214, 194, inf, inf, inf, 429, inf, 457, 116, inf, 239, inf, 677, 824, 100, 432, inf, inf, 473, inf, 408, inf, inf, inf, 675, inf, 653, inf, inf, inf, inf, 634, 183, inf, inf, 217, inf, 112, inf, inf, inf, 961, 607, inf, 366, 590, 598, inf, 102, 144, inf, 205, 831, inf, inf, inf, inf, 630, 214, inf, 707, 175, 379, inf, 156, 100, inf, inf, inf, inf, inf, inf, 558, inf, 557, 427, 540, inf, inf, inf, 433, 616, inf, 228, 134, inf, inf, 101, 794, 430, 189, inf, inf, 126, inf, 218, 370, 128, 348, 113, 151, 379, inf, inf, inf, 235, 206, inf, inf, inf, 753, 366, 251, 341, 135, inf, inf, 237, 237, 281, 130, inf, 182, inf, inf, 295, inf, inf, 252, inf, inf, 246, inf, inf, 273, inf, 446, inf, inf, 497, inf, 178, inf, 268, inf, inf, 698, 292, inf, inf, 120, 389, inf, inf, inf, 123, 204, 317, 662, inf, inf, 337, 241, 358, 388, 169, 618, inf, inf, 337, 221, inf, 101, 624, inf, inf, inf, inf, 196, 641, 283, inf, inf, 839, inf, 666, inf, 113, 773, inf, 195, inf, inf, 135, inf, inf, inf, inf, 223, 409, 459, inf, 367, 161, inf, 105, 270, inf, 481, 134, inf, inf, inf, inf, 110, 361, 216, inf, inf, inf, 101, inf, inf, 240, inf, inf, inf, 103, 176, 472, 227, 223, inf, inf, 645, 206, 205, 111, 440, 393, inf, inf, 272, inf, inf, inf, 526, inf, inf, inf, 128, 303, 169, 180, 310, inf, inf, inf, inf, 232, inf, 321, 349, inf, 283, 238, 219, 115, 255, 103, inf, 135, 328, 182, inf, 529, 119, 684, 169, inf, inf, 303, inf, inf, 165, inf, inf, inf, 119, 450, inf, 307, inf, 627, 249, inf, 327, inf, 761, 147, inf, inf, inf, 150, inf, inf, 271, 170, inf, inf, 500, inf, inf, 296, 527, inf, 350, inf, inf, inf, inf, inf, 417, 295, 132, inf, 339, 520, inf, 630, inf, 161, 493, 370, inf, inf, 115, 590, 101, 250, inf, inf, inf, 649, inf, inf, inf, 518, inf, 397, 112, 512, 103, 155, 673, inf, 287, inf, 320, 163, 304, inf, 734, inf, inf, 477, 428, inf, 258, 201, 128, 236, 189, 177, inf, 106, inf, inf, 117, inf, inf, inf, inf, inf, 156, 221, inf, 364, inf, 221, 431, 351, 204, 185, 230, inf, 115, inf, 619, inf, inf, inf, 223, 456, inf, 156, inf, inf, 333, inf, 246, inf, 583, 410, 480, 514, inf, inf, inf, 405, inf, 280, inf, 626, 319, inf, 351, 178, inf, 132, 138, 159, 396, inf, inf, inf, inf, 331, inf, inf, 587, inf, inf, inf, inf, 475, inf, inf, inf, 130, inf, 566, 304, 121, inf, inf, 734, inf, inf, inf, 284, inf, 112, inf, inf, inf, 126, 282, inf, inf, inf, 842, inf, inf, inf, 725, 234, 469, 184, inf, inf, inf, 112, inf, 129, inf, 183, inf, 507, inf, 333, inf, inf, inf, inf, inf, inf, 419, inf, inf, inf, inf, 187, 193, inf, inf, inf, inf, 304, 245, inf, inf, 240, 104, inf, 240, 122, inf, inf, 233, 101, inf, 249, inf, 197, 126, 227, 328, 691, 536, 228, inf, 583, 227, inf, inf, inf, inf, inf, inf, 118, 196, inf, 172, 100, inf, 100, 536, 357, inf, 131, inf, inf, 172, 136, inf, inf, 263, 349, inf, inf, inf, inf, inf, 182, 133, inf, inf, inf, 223, inf, inf, inf, inf, inf, 487, 178, 459, 290, 229, inf, 112, inf, inf, 344, inf, 417, inf, inf, inf, 647, 169, inf, 344, 399, inf, 360, 100, 108, 661, 163, 534, 106, 185, 702, 213, inf, 700, inf, inf, 249, inf, inf, inf, 263, 729, 275, 120, 466, 242, 152, 379, inf, inf, inf, inf, 277, 640, 674, 146, inf, 332, inf, inf, inf, 584, inf, inf, inf, inf, 205, inf, 372, inf, inf, inf, inf, 157, inf, inf, inf, inf, 142, inf, inf, inf, 572, 628, 150, 177, 300, inf, 246, 230, inf, inf, 179, 444, inf, inf, 499, 126, inf, 185, 361, 148, 883, inf, 221, inf, 168, inf, inf, inf, inf, inf, 837, inf, 114, inf, 744, 182, inf, inf, 133, 114, 505, 127, inf, 113, inf, 334, 782, 138, inf, inf, inf, 507, 290, inf, inf, 178, 558, inf, inf, inf, 153, inf, inf, 144, 696, inf, 101, inf, 547, inf, 114, inf, 246, inf, inf, inf, inf, 499, inf, 189, inf, 250, 108, 161, 272, inf, inf, inf, 243, inf, 515, inf, 249, inf, inf, 433, 421, inf, inf, 161, inf, 137, inf, inf, 654, inf, 126, inf, 342, 343, 117, 740, 235, 153, inf, 413, 108, 801, 266, 210, inf, inf, inf, 502, inf, inf, 227, inf, 568, inf, 101, 155, inf, 155, inf, inf, 194, inf, 361, inf, 256, inf, inf, inf, 214, inf, inf, 135, 672, 313, 177, inf, inf, inf, 615, inf, inf, inf, 428, 479, inf, inf, inf, 191, inf, inf, 148, 197, inf, 461, 683, 789, 385, inf, 173, 148, 368, inf, inf, inf, inf, 498, 103, 468, inf, inf, inf, 189, 274, 559, 228, inf, 104, inf, 524, inf, 165, 262, inf, 259, 300, inf, 111, 449, 111, inf, inf, 419, inf, inf, 762, 129, inf, 370, inf, 175, 106, 179, 106, 467, 141, 368, inf, 107, 331, inf, 160, 598, 107, 641, 159, inf, inf, inf, 653, inf, 513, 133, inf, inf, 667, 240, inf, 130, inf, 378, inf, inf, inf, 474, 620, 323, inf, inf, inf, 251, 164, inf, 185, 313, inf, inf, 299, inf, inf, inf, 165, inf, 152, 682, 435, inf, inf, 130, inf, 568, 209, 418, inf, 506, 544, inf, inf, inf, 342, inf, inf, inf, 816, 304, inf, inf, inf, 445, inf, inf, 178, 437, 487, 211, inf, 446, inf, 179, 140, 481, inf, inf, 120, 122, inf, 102, 661, 159, 151, inf, 182, inf, inf, 135, 382, 131, 131, inf, inf, 198, inf, 414, 769, inf, inf, 640, inf, inf, 484, inf, inf, inf, inf, inf, inf, inf, 107, 317, 447, 402, inf, inf, 672, 320, 786, inf, inf, 514, 214, inf, inf, inf, 541, inf, 622, 119, 119, 296, inf, inf, 294, inf, inf, 233, 129, inf, 563, inf, 133, 551, 338, 356, inf, inf, inf, inf, 104, 266, 353, inf, 236, 421, inf, 145, 349, inf, inf, 261, 300, inf, 124, 227, 615, inf, 468, 126, inf, 569, inf, 254, 389, inf, inf, inf, 343, 325, inf, 112, 244, inf, inf, inf, inf, inf, 106, inf, 267, inf, inf, 149, inf, inf, inf, inf, inf, inf, 112, inf, 123, inf, 241, inf, 284, 294, inf, inf, 339, 468, inf, 293, inf, 615, inf, inf, 529, 149, inf, 657, inf, inf, inf, 237, inf, inf, inf, 358, inf, inf, 136, inf, 420, 138, 456, 193, 158, 106, 280, inf, inf, 514, inf, inf, 277, 332, 649, inf, 160, inf, inf, 153, 935, 861, inf, inf, 249, inf, 222, 278, inf, 258, 388, 213, 269, 101, inf, inf, inf, 149, inf, 462, 490, 467, inf, 136, 102, 228, 515, inf, inf, inf, 706, 211, inf, 168, inf, inf, 346, 258, 162, inf, inf, 137, 833, inf, inf, inf, 678, inf, inf, inf, inf, inf, 221, inf, 497, inf, 135, 369, inf, inf, 129, inf, 263, inf, 391, 212, inf, inf, 259, inf, 169, 171, 106, inf, inf, inf, inf, 337, 479, inf, 348, 397, inf, 160, inf, 735, 481, inf, 183, inf, inf, 158, inf, 607, inf, inf, inf, inf, 211, inf, 245, 256, 234, 610, inf, inf, inf, 120, 395, inf, inf, 117, inf, 500, inf, 215, 244, 171, 113, inf, inf, 418, 482, 354, 691, 176, inf, 347, inf, 664, 660, inf, 719, 156, inf, inf, 128, inf, inf, 379, inf, 206, 426, inf, inf, 194, inf, 579, inf, 208, 498, 442, inf, inf, inf, inf, inf, 482, 936, 280, 111, 595, inf, 323, inf, 252, inf, 163, inf, 378, inf, 105, 109, inf, inf, inf, inf, 468, inf, 404, inf, 169, inf, inf, 465, 282, inf, 110, 345, inf, inf, 428, 197, inf, inf, inf, 123, inf, inf, inf, 296, 123, 504, inf, 119, inf, inf, 151, 114, inf, 210, inf, inf, inf, 251, inf, 137, inf, 112, 729, 657, 257, inf, 159, inf, inf, 138, inf, inf, inf, 580, inf, 104, inf, inf, 654, inf, 187, 102, 292, 106, 105, 293, inf, 283, inf, inf, 404, inf, inf, inf, inf, 250, 115, inf, inf, inf, 270, inf, inf, inf, 317, 200, inf, inf, 101, 131, inf, inf, inf, 681, 675, 224, inf, 327, 129, 147, inf, 134, inf, 428, inf, inf, inf, 295, inf, 310, 680, 148, inf, 130, inf, inf, inf, inf, inf, 380, 163, 233, inf, 536, inf, inf, 106, 523, 270, 198, inf, inf, 120, 138, inf, 540].\n",
      "Predicted change points: [562, 55, 131, -1, 178, -1, 328, 181, 344, -1, 84, 407, 136, 68, 305, 231, 73, 655, 82, 177, 91, 164, -1, 156, 77, 425, 227, 424, -1, 199, -1, 54, 528, 493, 183, 428, 74, 127, 392, 490, 131, 208, 208, 504, 143, 206, 170, 164, 122, 641, 260, 81, 236, 124, 244, 111, 171, 85, 166, -1, 255, -1, 52, 66, 554, 159, 109, 501, 82, 77, 156, 281, 203, 199, 56, 121, 73, 269, 210, 50, 104, 61, 50, 226, 92, 95, 74, 164, 348, 149, 97, -1, 56, 150, 203, 68, -1, 622, 281, -1, -1, 110, 150, -1, 139, 283, -1, 81, 115, 258, 75, 67, 387, 190, 531, 90, -1, 146, 80, 151, 80, 51, 340, 151, 113, 139, 322, 255, 586, 178, 376, 417, 52, 327, 562, 440, 50, 189, 52, 109, 52, 50, 189, 105, 201, 244, 386, 65, 293, 895, 241, 84, 148, 99, -1, 198, 72, 69, 108, 119, 628, 55, 227, 301, 145, 149, 161, -1, 473, 292, 116, 138, 428, 286, 130, 367, 195, 55, -1, 118, 281, 164, 57, 380, 126, 134, 120, 631, -1, 152, 951, 313, 143, 115, -1, 113, 161, 212, 50, 70, 65, 72, 106, 492, 128, 288, 121, 152, -1, 348, 208, 188, -1, 200, 91, 219, 238, 148, 296, 67, 83, 141, 220, -1, 123, 111, 216, 139, -1, 318, 64, 344, -1, 193, 164, 316, 326, 106, -1, 102, -1, 354, 384, -1, 138, 131, 404, 325, 323, 86, 120, -1, 125, -1, 72, 95, 97, 60, 238, 100, 431, 234, 177, 224, 98, 322, 291, 425, 230, -1, 213, 182, 128, 57, 155, 124, 59, 315, 670, 134, -1, 114, 64, 118, -1, 375, 301, 231, 420, 197, 215, 324, 209, 268, 128, 115, 93, 506, 57, 141, 382, 321, 112, 171, 231, 130, 259, 532, 327, 87, 412, -1, 166, 165, 116, 133, 178, 307, -1, 69, 115, -1, 244, 102, 129, 657, 97, 269, 609, 93, 251, -1, 147, 107, 114, 60, 78, 152, 148, 99, 125, 81, 146, -1, 204, 336, 193, 637, 161, 183, 263, -1, 139, -1, 217, 299, 149, 238, 144, 346, -1, 85, 101, 56, -1, 625, 122, 194, -1, 151, -1, 170, 96, 117, 76, 137, -1, 58, 204, -1, 81, 168, 221, -1, 259, 416, 298, 51, -1, 334, -1, 201, -1, 487, 270, 174, 50, 289, -1, -1, 143, 377, 135, 115, 197, 399, 521, 153, 109, 214, 109, -1, 60, 589, 306, 306, 88, -1, 166, 137, 123, 216, 368, 122, -1, 147, 106, 551, 194, 86, 303, 196, 111, 177, 63, 114, 97, 149, 323, 183, -1, -1, 55, 243, 151, 67, 62, 595, -1, 240, 298, 586, 50, 72, 50, -1, 235, 377, 214, 389, 415, -1, 65, 50, 323, 219, 160, 256, 502, 122, 127, 191, 125, 178, 240, 351, 74, 309, 142, 88, 300, 50, -1, 79, 163, 274, 253, 397, 137, -1, 637, 307, 129, 82, 260, -1, 513, 166, 696, 708, 644, 82, 58, 50, 153, 196, 164, -1, -1, 82, 224, 183, 160, 184, 135, 162, -1, 433, 138, 423, 298, 115, 638, 134, 157, 57, 62, 252, 88, 142, 75, 52, 352, 132, 588, 280, 65, 82, 72, 577, 220, 214, 88, 621, 55, 178, 289, 141, 350, 86, 210, 401, 60, 428, 87, 291, 109, 185, 165, 167, 219, 226, 427, 213, 479, 211, 815, 50, 116, 224, -1, 199, 66, 159, 50, 68, 454, 131, 151, 86, 149, 65, 152, 198, 182, 142, 119, 159, 123, 89, 179, 80, 186, 359, 276, 257, 169, -1, 168, 160, 140, 120, 204, 234, 53, 399, 111, -1, 232, -1, 80, 243, 169, 300, 64, 140, 117, 243, 220, 142, -1, 119, 157, -1, -1, 151, 166, 187, 55, 493, 115, 97, 162, 164, 542, 95, 242, 58, 126, -1, 93, 309, 140, 340, 117, 50, 461, 80, 341, 227, 266, -1, 161, 270, 222, 172, -1, 130, 50, 90, 214, -1, 158, 201, 183, 58, 100, 161, 52, 175, 483, 216, 606, 85, 52, 87, 328, 474, 127, 342, -1, 168, 55, 384, 103, 415, 111, 65, 206, 255, 67, 73, 251, 67, 119, 92, 62, -1, 92, 161, -1, 60, 98, 115, 341, 96, 101, 80, 321, 64, 182, 199, 644, 188, 301, 184, 299, 123, 263, -1, -1, 128, 58, 268, 50, -1, -1, 235, -1, 134, 263, -1, 59, 287, 114, 194, 408, -1, -1, 75, 361, 238, 76, 789, 81, 189, 214, 59, 91, 456, 365, 301, 103, 118, 132, 195, 166, 173, 149, 215, 50, 346, 693, 144, 360, 164, 456, 445, 189, 466, 436, 178, 469, 67, 209, 160, 61, 60, 58, -1, -1, 111, 63, 292, 131, 153, -1, 171, 243, 298, 70, 78, 100, 303, 137, -1, 66, 76, 208, 129, 290, 110, 485, 147, 214, 76, 99, 382, 384, 250, 97, -1, 449, 69, 60, 215, 65, -1, 165, 327, 263, -1, 69, 351, 82, 211, 351, 221, 286, 532, 116, 361, -1, 162, 53, 57, 168, 483, 318, 183, 50, 337, 103, 65, 291, -1, 171, 155, -1, 148, 134, 144, 98, 183, 204, 109, 185, 209, 272, 487, 58, 112, 288, -1, 295, 76, -1, 50, 57, 156, 50, 241, 344, 149, 297, 250, 127, 241, 306, -1, 101, 67, 146, -1, 392, 93, 162, 137, -1, -1, 180, 533, 175, 437, 118, 189, 112, 315, 160, 58, -1, 246, 408, 530, 174, 65, 181, 204, 212, 167, 275, 229, 231, 180, 184, 146, 402, 97, 78, 312, 154, 382, 103, 226, 259, 380, 134, 263, 71, -1, 121, 208, -1, 192, -1, 83, 93, 134, -1, 127, 199, 300, 59, 104, 222, 52, 79, 107, 55, 121, 289, 348, 234, 198, 326, 331, 262, 216, 50, 121, 236, 59, 163, 67, 72, -1, 252, 138, 510, 140, 340, 74, 123, 411, -1, 275, 472, 50, 559, 415, 385, 158, 151, -1, 85, 50, 97, 215, 377, 220, 70, 52, 320, 95, 282, 166, 107, 128, 204, 164, 371, 142, 213, 108, 300, 122, 251, 50, 485, 369, 60, 158, 164, 203, -1, 120, 245, 67, 58, -1, 201, 60, 117, -1, 158, 353, 421, -1, 120, 206, 135, -1, 156, 251, 186, 140, 115, 499, 152, 77, 159, 473, -1, 78, 100, 150, 93, 188, 337, 179, -1, 184, 58, 83, 167, 72, 346, 68, 299, 222, 308, 398, 337, 91, 131, 344, 145, 371, 416, 248, 130, 313, 135, 60, -1, 220, 417, 265, 245, 126, 358, 188, 799, 50, 108, 148, 81, 134, 142, -1, 123, 54, 131, 109, 378, 224, 292, 95, 215, 112, 133, 223, 142, -1, 62, -1, 61, 443, 228, -1, 254, 528, 134, 488, 143, 445, 296, 199, 176, -1, 131, 182, 68, 126, -1, 229, 168, -1, -1, 307, 231, 51, 99, 101, 62, 174, 147, 363, 132, 182, 135, 364, 74, 50, 229, 60, 193, 540, 163, 374, 201, 254, 272, 277, 354, -1, 294, 295, 157, 185, 737, 118, -1, 142, -1, 161, 98, 79, 80, 468, 65, 85, 129, 85, 172, 204, -1, 158, 111, 161, 209, 78, 116, 94, 265, -1, -1, -1, 103, 167, 280, 265, 110, 50, 85, -1, 275, 58, -1, 227, 304, 698, 108, 150, 348, 197, -1, 175, 179, 78, 82, 267, 772, 163, 108, 174, 140, 98, 621, 136, -1, 207, 106, 374, -1, 110, 434, 119, 81, 132, 124, -1, 576, 194, 690, 215, 456, -1, -1, 97, 89, 80, 195, 96, 128, 95, 518, 97, 133, 226, 110, 422, 483, 91, 143, 160, 180, 278, 425, 417, 401, 113, 131, 121, 125, -1, 97, -1, 122, 140, 163, 371, 123, 327, 141, 106, -1, 161, 50, 182, 287, 51, -1, 60, 380, 458, 165, 216, -1, 330, 219, 101, 101, 285, -1, 280, 66, 218, -1, 214, 61, 86, -1, 326, 121, 132, 362, 87, 66, 161, 269, 163, 315, 149, 54, 308, 103, 310, 786, 338, 212, 190, 118, 141, -1, 575, 297, 62, -1, 311, -1, 315, 490, 66, 218, -1, -1, 65, 240, -1, 182, 157, 217, 457, -1, 682, 57, 64, -1, 566, 90, 118, 101, 318, 488, 366, 176, 429, 327, 112, 160, 103, 95, 255, 320, 50, 103, 87, 473, 76, 167, 174, 98, 162, 95, 50, 549, -1, 271, 148, 50, 133, 190, 233, -1, 157, 321, 83, 108, 473, 97, 81, 346, 62, 460, 50, 116, 574, 65, 105, 167, 212, 156, 99, 84, 70, 237, -1, 155, 115, 134, 186, -1, 162, 292, 50, 230, 787, 479, 203, 314, 114, 126, 269, 135, 288, 191, 315, 189, 144, 857, 279, 88, -1, 212, 182, -1, -1, 222, -1, 182, 380, 150, 183, 173, 99, 136, 130, 50, 257, 261, 57, 168, 147, 127, 316, -1, 163, 72, 145, 193, 86, 158, 50, 302, -1, 173, 95, 244, 121, 206, 69, 360, 173, -1, 214, 685, 179, -1, 72, 120, 75, 57, 415, 142, 158, 134, 169, 94, 289, 143, 106, -1, 135, 332, 192, 92, 50, 72, 332, 185, 783, 664, 182, 244, 248, 631, 243, 195, 252, -1, 124, 122, -1, 118, 487, -1, 209, 77, 113, -1, 376, 615, 562, -1, -1, 98, -1, 500, 118, 159, 50, 293, 252, 68, 378, 254, 373, -1, 81, 64, -1, -1, 190, 67, 660, 179, 250, 166, 93, 136, 218, -1, 267, 580, 112, -1, 99, 79, 303, 152, 142, 268, 80, 224, 245, 122, 296, 54, 707, -1, 224, 138, 108, 93, -1, 54, 404, -1, 364, 207, 304, 534, 166, -1, 166, 86, -1, 121, 67, 57, -1, 214, 354, 326, 134, 214, 369, 57, 127, 185, 534, 397, 145, 124, 154, 74, 137, -1, 163, 155, 73, 190, 60, 169, 326, 485, -1, 900, 218, -1, 52, 74, 99, 151, 417, 261, 348, 126, 118, 203, 354, 333, 101, -1, 69, 131, 158, 51, -1, 93, 289, 50, 304, -1, 405, 317, 63, 133, 66, 153, 277, 159, 147, 359, 54, 74, 485, 311, 153, 113, 597, 100, 305, 190, 129, 86, 342, 294, 164, 106, 71, 119, -1, 50, 212, 204, 97, 87, 329, 232, 196, 120, 50, 105, 311, 452, 522, 187, 98, 240, 419, 113, 82, 56, 189, 183, 287, 108, 157, 193, -1, -1, 279, 82, 88, 87, 307, 117, 263, 148, 124, 381, 191, 125, 143, 170, 178, 75, 115, 87, 586, -1, 58, 121, -1, -1, -1, 415, 159, -1, 55, 178, 176, 387, 127, 62, 468, 501, -1, 136, 124, 97, 194, -1, 120, 98, 115, 97, 84, -1, 360, -1, 145, 200, 625, 162, 277, 154, 92, 50, 75, 130, 61, 662, 725, 286, 311, 91, 224, 133, 171, 94, 117, -1, 226, 211, 119, 391, 276, 296, 650, 255, 176, 112, 84, 592, 135, 60, -1, 231, 67, 203, 143, -1, -1, 298, 56, 151, 115, 556, 196, -1, -1, 297, 120, 334, 533, 50, 438, 99, 243, 159, 205, -1, 299, -1, 396, -1, 280, 508, 195, 115, 118, 74, 594, 138, 194, 172, 52, 264, 144, 212, 120, 360, 445, -1, 419, 581, 703, -1, 178, 201, 174, -1, 368, 324, 421, 273, 175, -1, 196, 270, -1, 287, -1, 73, 109, -1, 138, 82, 123, 68, 237, -1, 163, 76, 90, 173, 675, 128, 319, 391, 123, 63, 235, 93, 71, 192, 337, 460, 67, 628, 106, 382, -1, -1, 108, 57, -1, 128, 125, 54, 249, 176, 163, 76, 127, 111, 514, 148, -1, -1, 305, 156, 199, 155, -1, 392, 98, 110, 120, 358, 64, 474, 131, 131, -1, 171, 179, 150, 138, 133, -1, 167, 94, 157, 70, 167, -1, 53, 377, 413, 274, 163, 69, -1, 352, 439, -1, 361, 117, -1, 182, 222, 52, 136, 107, 458, 145, 64, -1, -1, 53, 175, 64, 203, 117, 233, 550, -1, 56, 129, 645, 540, 206, 72, 302, 203, 195, 90, 354, 370, 400, 50, -1, 395, 81, 129, 54, -1, 249, 107, 192, 218, 449, 313, 155, 317, -1, 118, 249, 104, 129, 156, 115, 87, 295, 260, -1, 251, 333, 111, 65, 169, 250, 50, -1, 238, -1, 149, 102, 360, 211, -1, -1, -1, 182, -1, -1, 190, 80, 53, 190, 176, 66, 214, 913, -1, 82, 107, 383, 208, 215, 204, 485, 81, 476, 140, -1, 188, 70, 50, -1, 89, 186, 219, 176, 81, 102, 222, 306, 267, 139, 66, 164, 235, 216, 87, 104, 113, 364, 118, 161, 249, 145, 364, 167, 60, 226, -1, 179, 50, 226, 194, 356, 296, 443, 119, 273, 604, 482, 323, 207, 593, 167, 175, 250, 381, 356, 66, 79, -1, 559, -1, 183, 139, 112, 122, 137, 374, -1, 431, 131, 113, 106, 177, 50, -1, 561, 138, 111, 97, 122, 71, 302, 53, 257, 227, 59, 345, 145, 205, -1, 70, 62, 443, 238, -1, 573, 171, 253, 77, -1, 60, 165, 150, 408, 131, 290, 253, -1, -1, 307, 137, -1, 150, 82, 286, 118, 613, 50, 51, 120, 106, 180, -1, 62, -1, 244, 207, 351, 50, 282, 73, 213, -1, 220, -1, 335, 118, 465, 177, 50, 58, 61, 72, 169, 166, 366, 61, 92, 142, 50, 252, 190, 797, 498, 223, 59, 333, 190, -1, 61, 83, -1, -1, 210, -1, 277, 94, -1, 385, 201, -1, 105, 134, 66, -1, 274, 114, 143, -1, 86, 72, 154, 65, 322, 68, 78, 185, 393, 165, 50, 133, 168, 155, 336, 261, 55, 373, 191, -1, -1, -1, 196, 357, -1, -1, 130, -1, 51, 106, 269, 50, 226, 209, 52, 135, 228, 194, 78, 266, 158, 242, 412, 85, 115, 154, -1, 203, 183, 197, 230, 167, 208, 268, 97, 216, 368, -1, 156, 101, 262, 279, 150, 97, -1, 269, 52, 65, 112, 119, 187, 200, 127, -1, 186, 69, 416, 135, 389, 165, 106, 206, -1, 74, 568, -1, 104, 194, 186, 76, 308, 304, 116, -1, 97, -1, 108, -1, -1, 50, 87, 167, 67, 70, 66, 323, 136, 94, 51, 576, 70, -1, 62, 297, 151, 169, 129, 270, 118, 64, 53, 230, 96, 499, -1, 56, 225, 202, 290, -1, 144, 101, 273, 181, 118, 149, 361, 236, -1, 91, -1, 79, -1, 135, 263, 814, 68, 50, 210, 482, 206, 108, 276, 124, 80, 670, -1, 111, 108, 311, 50, 88, 523, 140, 58, -1, -1, -1, 112, 125, 111, -1, 190, 185, 142, 166, 297, 146, 598, -1, 82, 135, 173, 133, 423, 201, 62, 188, 79, 154, 234, 221, 74, 291, 50, -1, 193, 137, -1, 69, 729, 222, 235, 244, 88, -1, 94, 101, 177, 55, -1, 83, 85, 283, 224, 547, 296, 290, 314, -1, 258, 198, 468, 174, 263, 256, -1, 302, 74, -1, 118, -1, -1, 96, 368, -1, 199, 332, 298, 95, 157, 160, 231, 155, 379, 102, 240, 198, 72, 119, 145, 57, 362, -1, 220, 144, 259, 54, 391, 124, -1, 190, 214, 79, 80, 264, 136, 302, -1, 273, 67, 129, 112, 298, 312, 67, -1, -1, 81, 84, 64, 291, 115, 194, 110, 84, 115, 174, 354, 69, 149, 129, 83, 204, 358, 85, 172, 210, 178, -1, 170, 180, 295, 104, 233, 173, 66, 141, 253, 608, 593, 100, 262, 231, 65, 89, 111, 115, 205, 180, 101, 166, -1, -1, 123, -1, 117, 125, -1, 753, 137, 213, 426, 144, 392, 83, -1, 505, 406, 113, 50, 50, -1, 187, 83, 248, 81, 235, 50, 186, 167, 137, 446, 250, 650, 258, 111, 494, 112, 339, 169, 327, 151, 286, 327, -1, -1, 214, 276, 123, -1, 547, -1, 379, 169, 88, 235, 50, 59, 112, 376, 50, 79, 607, -1, 254, -1, 65, 334, 135, 51, -1, 204, 182, 50, -1, 438, 371, 564, 295, 293, -1, 149, 272, 691, 66, 272, 62, 205, 93, 187, 230, -1, 105, 156, 341, 247, 270, 102, 232, 161, 165, 82, 133, 88, 104, 544, 114, -1, -1, 50, 148, 50, -1, 68, 85, 81, 76, -1, 131, 553, 81, 141, 69, 214, 207, 129, 364, 169, 155, 113, -1, -1, -1, 264, 285, 358, 153, 112, 167, 271, 62, -1, 465, 209, 62, 105, 129, -1, 560, 370, 561, -1, -1, -1, 155, 223, 69, 782, 279, 91, 140, 299, 253, 261, 133, 143, 120, 611, 367, 127, 94, -1, 112, 387, 383, -1, 187, 236, 119, 202, 253, -1, 270, 134, 210, 134, 130, 183, 186, 159, 175, 192, 302, 296, 539, 462, 283, 120, -1, 67, 204, 507, 50, 123, 671, 220, 150, 88, 85, 405, 152, 129, 518, 136, 173, 167, 106, 511, 448, 185, 128, 147, 471, 200, 144, 256, 178, -1, 50, 459, 244, 191, 230, 176, 112, 263, 101, 114, 67, 136, 167, 279, 173, 130, 713, 177, 302, 53, 290, 260, 190, 528, 194, 159, 358, -1, 235, 52, 82, 57, 87, 178, 274, -1, 72, 343, 225, 78, 524, 257, 160, -1, -1, 166, 140, 342, 141, -1, -1, 59, 299, 200, 226, 254, 115, -1, 180, 333, 258, -1, 110, 62, 137, 244, 322, -1, 62, 161, -1, 109, 169, 76, 113, 72, 265, -1, 161, 122, 151, 190, 248, -1, 107, 213, 119, 145, 198, 120, 133, 66, 199, 77, 179, 328, 230, 186, 158, 221, -1, 62, 272, 334, 146, -1, 253, 94, 291, 117, -1, -1, 128, 260, 109, 303, -1, 335, 174, 164, 226, 217, 123, 52, -1, 801, 187, 203, 310, -1, 83, 714, 351, 116, 141, 97, -1, -1, 228, 173, 282, -1, 57, -1, 161, 137, -1, 52, 67, 77, 141, 360, 346, 324, 122, 102, 304, 156, 145, 73, 500, 111, 137, 93, -1, 84, 50, 150, 86, 50, 503, 231, 178, 243, -1, 711, 262, 146, 152, 315, 247, 288, 148, 95, 100, 72, 105, 195, 120, 105, 111, 796, 55, 425, -1, 75, 75, -1, 168, 112, 193, 130, 146, 52, 141, 167, 546, 208, 138, 173, -1, 181, 123, 552, 282, -1, 476, 160, 186, 721, 69, 73, 221, 257, 119, 50, 210, 169, 201, 142, -1, 155, 81, -1, 88, 208, 119, 164, 66, 699, 110, 622, 370, 215, 163, 51, 132, 215, 173, 100, 177, 394, 110, 131, 237, 177, 607, 147, 179, 190, 604, 566, -1, -1, 409, 135, 767, 100, 142, 91, -1, -1, 135, 309, 63, 269, 171, 163, 236, 70, -1, 496, -1, 154, 132, 85, 76, 111, 116, 168, 106, 59, 123, 122, 208, 78, 181, 289, -1, 594, 481, 55, 124, 84, 205, 99, 116, -1, 57, -1, -1, 180, 403, 170, 327, 185, 126, 90, 131, 99, 159, -1, 67, 71, 93, 441, 73, 50, 50, 490, 212, -1, 74, 676, 77, 88, 226, 117, 66, 130, 180, 233, -1, 278, 76, 194, 58, -1, 117, 151, -1, 327, 589, 557, -1, -1, 778, 67, 113, 196, 57, 395, -1, 170, 193, -1, 123, 130, 265, 240, 134, 534, 139, 266, 56, 210, 403, 116, 478, 50, 112, -1, 60, 55, 82, 104, 110, 141, 115, 204, 129, 281, 351, 262, 117, 168, 108, 199, 102, 292, 200, -1, 174, 368, 111, 207, 248, 189, 407, 304, 110, 192, 135, 248, -1, 252, 150, 359, 538, 289, 166, 455, 325, 181, 156, 168, -1, 57, 295, 73, 190, -1, 131, 93, 101, 225, 343, 54, 218, 276, 73, -1, 86, 293, 122, 177, 349, 68, 240, -1, -1, 245, 672, 94, 223, 322, 168, 304, 140, -1, 251, 548, 52, -1, 200, 172, 371, 97, 325, 170, 58, 156, 206, 207, 114, 268, 242, -1, -1, 108, 218, 199, 115, 86, 206, 250, 448, 513, 360, 124, 158, 108, 50, -1, 195, 50, 107, -1, 90, 50, -1, 225, 162, 103, -1, -1, 122, 493, 174, 472, 298, 151, 205, 229, 711, 497, 140, 50, -1, 95, -1, 231, 116, 234, 220, -1, 172, 92, 125, -1, 79, 225, 166, 81, 138, 323, 274, -1, 107, 118, -1, 184, 117, 220, 50, 344, 300, 326, 88, 284, 50, 408, 316, 606, 146, 487, 305, 402, 125, 53, 118, 225, 111, 83, 83, 127, 72, -1, 427, -1, 163, 132, 291, -1, 215, 184, 508, 219, 133, -1, 267, 66, 259, 183, -1, 899, 82, 142, 59, 123, -1, 52, 127, 203, -1, 124, 116, 68, -1, -1, 117, 154, 148, 146, 52, 50, 312, 166, 259, 347, 175, 434, 125, -1, -1, 129, -1, 319, -1, 192, 201, 354, -1, 621, 244, 108, 105, 122, 114, -1, 241, 255, 50, -1, 116, 143, 255, 182, 303, 246, 60, 226, 243, 327, 164, 109, 437, 95, 237, 108, 397, 227, 125, 96, 198, 65, 94, 66, 156, 125, 130, 87, 143, 85, -1, 139, 126, 109, 316, 148, 153, 326, 90, 120, 68, 169, 50, 149, 505, 306, 264, -1, 341, 160, 325, 149, -1, 371, 479, 569, 913, 97, 355, 616, 197, 258, 83, 103, 289, 730, -1, 228, 100, 340, 50, 298, 86, -1, 200, 151, 380, 234, 199, 63, 148, 134, 193, -1, 92, 131, -1, 80, 294, 57, 158, 53, 170, 79, 289, 151, 133, 67, 331, 189, 224, 118, 50, 488, -1, 678, -1, 126, 290, 280, 165, 116, 239, 107, 110, 77, 354, 56, 514, 131, 50, 199, 361, 187, 231, 80, -1, 425, 293, 199, 455, 87, -1, 596, 83, -1, 68, 74, 337, 98, 50, 163, -1, 68, 118, 66, 137, 335, 554, 135, 304, 117, 166, -1, 104, 201, 145, 102, -1, 273, 492, 212, -1, 414, 329, -1, 176, 85, 221, -1, 112, 215, 51, 142, -1, 55, 323, 170, 515, 250, 248, 227, 153, 376, 50, 194, 51, 175, 126, 641, 115, 126, 130, 404, 162, 221, -1, 314, 227, 225, 155, -1, 250, 457, 86, 90, 139, 117, 107, 108, 77, 153, 297, 280, -1, 276, 100, -1, 184, 289, 227, 58, 312, 713, -1, 167, 82, 232, 88, 99, -1, 275, 59, 57, 529, 140, 877, 251, 128, 331, -1, 105, 50, 146, 341, 96, 119, 511, 91, 98, 388, 339, 168, 157, 233, 347, 50, -1, 99, 124, -1, 243, 297, 184, 105, 88, 50, 225, 132, 387, 204, 155, 179, 116, -1, 254, 171, 422, 306, 71, 181, 108, 119, 123, 346, 346, 286, 88, -1, 148, 250, 234, -1, 661, 274, -1, -1, 253, 163, 287, 497, 202, 149, -1, 164, 219, 147, -1, 210, -1, -1, 68, 111, 101, 92, 126, -1, 62, 60, 219, 89, 150, 147, -1, 130, 95, 112, 475, 99, 50, 112, 565, 377, 328, 371, 229, 125, 771, 564, 100, 175, 405, 55, 191, 191, 71, -1, 93, 144, 200, 210, 150, -1, 165, 267, 63, 244, 360, 369, 707, 50, 301, 55, 182, 309, 141, -1, 54, 170, 173, 403, 188, 106, 333, 334, -1, -1, 50, 62, 581, 92, 140, 241, 182, 192, 326, -1, 262, 272, -1, 73, 260, 51, 150, 265, 294, 53, -1, 441, 227, 228, 271, 263, -1, -1, 199, 378, 347, -1, 413, 58, 205, 149, -1, 192, 163, 199, 434, 461, 168, 126, 197, 58, 50, 453, 123, 152, -1, 161, 231, -1, 90, 193, 300, 288, 146, 306, 173, 52, 219, 393, 156, 140, 146, 67, 134, 99, 88, 115, 277, -1, 205, -1, 407, 329, 260, 63, -1, 199, 308, 75, 240, 568, -1, 100, 457, 195, 261, 73, -1, 91, 283, 83, 136, 166, 60, 169, 112, 341, 138, -1, 131, 76, 171, 160, 51, -1, -1, 181, 150, 183, 139, 240, 84, 60, 126, 301, 77, -1, 111, 71, 228, -1, 359, 195, 106, 400, 183, 152, 51, -1, 191, 58, 65, -1, 129, 285, 239, 133, -1, 178, 203, 430, 168, 81, 54, 109, 155, 172, -1, 108, -1, 266, 174, 88, 56, 279, 164, 54, 119, 302, 177, 50, 104, -1, 239, 358, 122, 263, 78, 75, 337, 155, 203, 214, 615, 50, -1, 275, 50, 163, 196, 95, 214, 76, 416, -1, 50, 339, 163, 135, 80, 352, 182, 56, 311, 151, 142, 233, 109, 51, 193, 100, 221, 208, 133, 70, 186, 95, 75, 134, 528, 133, 416, 509, 175, -1, 206, -1, 107, 168, 222, -1, 447, 50, 157, 91, 180, -1, 189, 450, 72, 225, 583, 124, -1, 193, 95, 398, -1, -1, -1, 124, 267, 51, 258, 235, 245, 232, 364, 237, 108, 151, 129, 91, -1, 304, -1, 120, 295, -1, 86, 80, 410, 102, 143, 145, 191, 222, 126, -1, 300, 489, 187, 200, 241, -1, 168, 315, 96, 161, 65, 51, 183, 120, 65, 50, 186, 754, 94, 363, 71, -1, 85, 184, -1, 157, 273, 238, -1, 402, 171, 128, 79, -1, 180, 126, 65, -1, 377, 111, 302, 114, 260, 232, 104, 190, 72, 215, 139, 374, 257, -1, 353, 140, 90, 90, 667, 386, 127, 308, 98, 337, 166, 169, 50, 78, 77, 132, 426, 89, 122, 270, 57, 179, 131, 97, 58, 215, 108, 155, 50, 161, 116, 68, 227, 144, 252, 352, 153, 233, 297, 526, 92, 119, 176, -1, 119, 157, 309, -1, 158, 141, 444, 129, 129, 94, 129, 126, 76, 112, 188, 312, -1, 93, 291, -1, 595, 78, 567, 111, 163, 53, 239, 168, 483, 220, 58, 408, 59, 253, -1, 52, 204, 91, -1, 622, 142, 273, 194, 342, 97, 231, -1, 82, 307, 368, -1, 100, 142, 188, -1, 151, 457, 737, 181, -1, 335, 102, 140, 58, 92, 80, 145, 113, -1, 559, 516, 106, 161, 274, 256, -1, 85, 252, -1, 134, 91, 121, 360, 560, 162, 254, 57, 90, 54, 54, 271, 192, 215, 418, 136, 128, 289, 312, -1, 84, 72, 171, 247, -1, 167, 205, 263, 51, 126, -1, 127, 231, 343, 158, 50, 183, 89, 66, 167, 286, 425, -1, -1, -1, 222, 99, 402, 733, 346, 65, 493, 239, -1, 51, 95, 696, 345, 241, 98, 289, 144, 147, 307, 169, -1, 198, 92, 432, 283, 178, 59, 80, -1, 108, 136, 298, 50, 437, 183, 131, 141, 187, 92, 94, 183, -1, 192, 145, 135, -1, 176, 103, -1, 90, 477, 53, 540, 113, 321, 75, 344, 170, 249, 74, 80, 92, 178, 250, 104, 88, 50, 61, 107, 64, -1, 211, 252, 442, -1, 209, 145, 160, 87, 181, 94, 165, 236, 296, 121, -1, 50, 53, 160, 444, 157, 116, 198, -1, 139, 90, 130, 185, 256, 96, 147, 50, 192, -1, 509, 125, 146, 134, 262, 333, 133, 118, 203, 356, 152, -1, 218, 358, 109, 243, 143, 194, 226, 144, 347, 112, 124, 131, 400, 249, 108, 442, 264, 396, 95, 89, 96, 133, 82, 51, 131, 130, 719, 425, 398, 114, 126, 130, 191, 214, 396, 407, 50, 516, 645, 293, 161, 628, 255, 70, 193, 180, 466, -1, 160, -1, 52, 420, 383, 192, 295, -1, 249, 72, 571, 410, 174, 136, 146, 98, 287, 69, 158, 290, 192, 50, -1, 158, -1, 113, 115, 85, -1, 64, 72, 140, 205, 148, 174, 138, 409, 136, -1, 289, 335, 120, 379, 121, 123, -1, 234, 148, 51, 66, 410, 418, 51, 741, 181, 329, 306, 205, 50, 222, 129, 79, 530, 166, 69, 63, 318, 50, 194, 259, 219, -1, 104, 50, 90, 55, 559, 234, 112, 220, 221, 124, 166, 136, 171, 96, 122, 159, 681, 87, 112, 97, 198, 50, 305, 156, 593, 119, 130, 442, 71, 220, 75, 171, 503, 115, 562, 229, 107, 50, -1, 127, 203, 64, 61, -1, 70, 152, 306, 50, 202, 289, 498, 140, 407, -1, 83, 181, 59, 497, 67, 51, 314, 163, 84, 555, 120, 107, 128, 269, 167, 209, 278, 292, 69, 305, 219, 225, 50, 536, 344, 577, 161, 587, 351, -1, 50, 339, 149, 55, 214, 529, 109, 52, 144, -1, 646, 484, 706, 264, 57, 174, -1, 206, 220, 670, 454, 434, 76, 127, 50, 222, 148, 131, 387, 604, 123, 243, 112, -1, 125, -1, 219, 102, 78, 107, 148, 107, 559, 149, -1, -1, 280, 132, 72, 89, 139, 536, -1, 605, 184, 50, 122, 503, 142, -1, 133, 227, 329, -1, 51, 122, 359, 134, -1, 595, 391, 549, 122, -1, 175, -1, 98, 134, 50, 82, -1, -1, 108, 131, 702, -1, 394, 168, 149, 125, 150, 300, 231, -1, -1, -1, 100, 210, -1, 116, 152, -1, 460, 156, 159, -1, 293, 415, 59, -1, -1, 91, 205, 83, 439, 163, 218, 510, 170, 234, 260, 143, 192, 113, 172, -1, 155, -1, 111, 93, 291, 55, 265, 170, 83, 163, 415, 302, 55, 179, -1, 316, 388, 375, 464, 192, 130, 325, -1, 138, -1, 434, 162, -1, 250, 200, 139, 78, 420, 111, 318, 541, 183, 114, 86, 161, 177, 81, 176, 146, 120, 299, 233, 150, 76, 147, 129, 310, 63, 395, 383, -1, 538, 276, 171, 94, 76, 153, 206, -1, -1, 139, 232, 50, 354, 161, 433, 52, 137, 335, 71, 549, -1, 84, 207, 510, 154, 183, 117, 104, 142, 105, 343, 134, 265, 74, 108, 188, 103, 132, 543, 214, 464, 169, 214, 357, 320, 284, 152, 52, -1, 381, -1, 269, 526, 58, 72, 231, 133, 119, 192, 180, 84, 401, 259, 182, 519, 142, 242, 82, 320, 116, 116, 120, 119, 108, 287, 58, 190, 126, 219, 59, 131, 85, 93, 77, 126, 177, 119, 157, 337, 241, 197, 228, 172, -1, 144, 95, 130, 64, 147, 430, 253, 135, 171, 322, 82, -1, -1, 193, 239, 282, 272, 319, 175, 136, 99, 72, 187, -1, 281, -1, 292, 172, -1, -1, 311, 130, 315, 70, 143, 280, 439, 342, 207, 180, 170, -1, 116, 156, 183, -1, 113, -1, 182, 276, 65, 289, 171, 93, 340, 122, 201, -1, 124, 208, 97, 66, 298, 97, 249, 350, 160, 195, 146, 182, 60, 137, 666, 279, 91, 293, -1, 182, 50, 176, 123, 87, 588, 379, -1, 569, 200, 160, -1, 268, -1, 213, 211, 152, 399, 130, 130, 63, 176, 143, 51, 153, 147, 139, 160, 72, 245, 177, 303, 344, 110, 130, 74, 367, 422, 125, 201, -1, 84, -1, 818, 165, 61, 173, 108, 211, 101, 262, 125, -1, 174, 192, 170, 214, 396, 104, 74, 188, 50, -1, 130, 117, 219, 99, 137, 119, 118, 183, 80, -1, 264, -1, 50, -1, 219, -1, 259, 90, 124, 132, 339, 113, -1, 150, -1, 115, -1, -1, 134, -1, -1, 285, 584, 50, 528, 87, 106, 104, 327, -1, 669, -1, 113, 246, -1, 123, 93, 147, 222, 152, -1, 79, 62, 520, 54, 183, -1, -1, -1, -1, -1, -1, 245, 210, 366, 118, 107, 72, 500, 115, 88, 443, 155, 125, 306, 124, 69, 59, 75, 166, 367, 88, -1, 202, 96, 140, 113, 225, -1, 222, 424, 111, 281, 310, 413, 479, 68, 272, -1, 302, 116, 266, 482, 115, 336, 71, 503, 109, 106, 77, 145, -1, 144, 74, 183, 195, 314, 309, 50, 189, 207, 133, 133, 155, -1, 185, 756, 96, -1, 63, 602, 120, 142, 266, 195, 121, 175, 175, 278, 93, 112, 85, 289, 148, 68, 219, -1, 59, 174, 281, -1, -1, 332, 223, 97, 604, -1, 225, 223, 73, 118, 50, 50, 94, 137, -1, 133, 195, 167, 756, 241, 423, 130, 113, 151, 83, -1, 84, 241, -1, 171, 197, -1, 230, 271, 287, 211, 355, 88, 339, 102, 127, 69, -1, 60, 134, 649, 163, 150, -1, 53, -1, 166, 110, 236, 114, 318, -1, -1, 255, 171, 136, 242, 248, -1, 87, 59, 281, 113, 199, 109, 118, 120, 80, 150, 339, 425, 369, 544, 152, 59, 265, 401, 58, 309, 164, 140, 50, 198, 80, 229, 180, 84, 303, 73, -1, 234, 368, 182, 50, 444, -1, 128, -1, 191, 173, 51, 88, 127, 154, 425, 244, 751, -1, 267, 107, 166, -1, 158, 55, 597, 50, -1, 104, 166, 303, -1, 50, 282, 280, -1, 485, 265, 364, 374, 85, 154, 141, 484, -1, 55, 67, 580, 108, 66, 359, 363, 190, 150, 138, 430, 152, 180, 77, 144, 210, 72, -1, 51, -1, 234, -1, 148, 199, 50, 120, 77, -1, 102, 246, 168, 97, 54, 180, 251, -1, 739, 402, -1, 183, 186, 122, 125, 110, 132, 260, 50, 152, 172, 202, 68, -1, 531, 81, 184, 67, 346, 558, 188, 494, 122, 491, 245, 51, 621, 184, 187, 50, 259, 337, 176, 59, 594, 56, 143, 233, 381, 327, 177, 117, 318, 63, 82, 298, 53, 57, 325, -1, 121, 121, 372, 129, -1, -1, 173, 337, 160, 145, 342, 83, 84, 607, 375, 197, 110, 679, 318, 52, 157, -1, 76, -1, 147, 268, 159, 224, 207, -1, 134, 54, 167, 129, 522, 220, 124, 64, 68, -1, 291, -1, 381, 75, 447, 130, 119, -1, 65, 702, 54, 369, 62, 208, 89, 120, 50, 609, 183, 98, 95, 424, -1, 134, -1, 483, 97, 262, 96, 109, 55, 580, 138, 183, 217, 107, 300, 308, 519, 134, 75, 213, -1, -1, 73, 310, 253, 200, 329, 373, 131, -1, 158, 314, 362, 619, 96, -1, -1, 65, 197, 249, 70, 216, 344, 136, 93, 169, 147, 124, 234, 648, 198, 196, 350, 87, 236, 203, 108, 339, 80, 150, 593, 631, 579, 334, 211, 220, 135, 275, 134, 50, 161, 107, 100, 341, 127, 100, 145, 228, 372, 173, 113, 311, 125, 464, 124, 143, 137, -1, -1, 76, 336, -1, 134, 450, 314, 122, 83, 152, 88, 60, 209, 194, 107, 203, 365, 204, 313, 58, -1, -1, 85, 208, 378, 87, 175, 139, 54, 295, 617, -1, 91, 173, 163, -1, 244, 128, 212, 120, -1, 134, 271, -1, 247, 89, 149, 129, 70, 95, 334, -1, 437, 160, 133, 120, 277, 187, 129, 50, 397, 75, 136, 52, 146, 94, 198, 279, 270, 104, 70, 90, 229, 63, 135, 386, 232, 55, 136, 437, 765, 252, -1, -1, 155, 87, 113, 190, 91, 111, 190, 209, -1, 313, 72, -1, -1, -1, 94, 309, 150, 457, 460, 128, 562, 273, -1, 289, 121, 196, 197, 176, 115, 79, 338, 163, 264, -1, 78, 633, 168, 216, 96, 86, 556, 113, 106, 233, 62, -1, 389, 64, 147, 131, 63, 171, -1, 107, 70, 379, 171, 301, 160, 357, 577, 187, 113, -1, 221, 344, 328, 363, 135, 367, 207, 217, 324, 165, -1, 104, 149, -1, 183, 227, -1, 105, 184, 264, 192, -1, 84, 159, 207, 250, -1, 100, 105, 166, 54, 210, 51, 127, 70, 134, -1, -1, -1, 161, 159, 256, 227, 154, 396, 164, 207, 123, 232, 171, 274, 132, 127, 328, 97, 342, 279, 296, 134, 72, 76, 121, 60, 57, 136, -1, -1, 101, 128, 285, 242, 373, 311, 170, 185, 85, 158, 59, 205, 374, 320, 119, 302, 145, -1, 131, 128, 190, 210, 386, 84, 130, -1, 50, 110, 370, 60, 226, 182, 50, 289, 265, 75, 109, -1, 472, -1, 129, 243, 385, 124, 429, 180, 119, 322, -1, 222, 59, -1, 93, 124, 134, 127, 52, 111, 116, 127, 161, 475, 655, 129, 182, 75, 188, 502, 344, 132, 115, 241, -1, 236, 488, 98, 221, -1, 358, 607, 59, -1, 624, 243, 208, -1, 419, 467, 50, 191, 68, 114, 384, 242, 466, 127, 200, 152, 98, 313, 234, 177, 379, 246, 50, 472, 339, -1, 122, 172, -1, 358, 392, 193, -1, -1, 193, 426, 189, 141, 163, 124, 177, 405, 385, 91, 150, 233, 412, 184, 50, 235, 595, 50, 55, 505, 219, 72, 230, 134, 50, -1, 117, 56, 63, 534, -1, 183, 53, -1, 122, 188, 198, 109, 141, 71, 200, 338, 50, 524, 215, 202, -1, -1, 100, 368, 411, 517, 265, -1, -1, 143, 139, -1, -1, 72, 103, 160, 51, 68, -1, 71, -1, 67, 250, 649, 136, 430, 63, 198, 55, 145, 108, 899, 129, 111, 117, 286, 140, 199, 253, 208, -1, 379, -1, 173, 373, 191, 224, 291, 137, 289, 89, -1, 252, 214, -1, 50, 232, 134, 371, -1, -1, 51, 118, -1, 297, 489, 220, 216, 105, 155, 54, 112, 126, 352, 129, 86, 219, 115, 157, 353, 54, 86, 236, 115, 97, -1, 541, 343, 116, 299, 755, 156, -1, 199, 484, 186, 168, 353, 54, 93, 313, 455, 83, 147, -1, 151, -1, 191, 177, 199, 73, 137, 107, 373, -1, 401, 221, 268, 199, 211, 248, 164, 409, -1, 162, 156, 395, 167, -1, 306, -1, 599, 80, 196, 65, 82, 636, 212, 200, 361, 85, 98, 146, 77, 88, 212, 68, 116, 119, 404, -1, 53, 209, 231, 197, 165, 557, -1, 86, 76, 455, 127, 129, 282, 202, 162, 112, 190, 63, 133, 278, 270, -1, -1, 297, -1, 183, -1, 158, 129, 109, 230, -1, 63, 453, 186, 326, 64, 101, -1, 130, 602, 50, 116, 53, 210, 148, 294, 228, 307, -1, 267, -1, 116, -1, 133, 439, 172, -1, 65, 51, -1, 107, 67, 167, 73, 322, 112, 160, 194, -1, 247, 432, 268, 130, 107, 329, 144, 522, 189, 248, 79, -1, 203, -1, 177, 188, 115, 327, 104, 59, 246, 171, 260, 67, 274, 156, 356, 323, 90, 362, 291, -1, 160, 111, 106, 436, 252, 629, 291, -1, 63, 408, 54, 119, 541, -1, 99, 160, 332, 541, 53, 218, 114, 407, 646, 214, 391, 280, 228, -1, 109, 132, 161, 180, -1, -1, 226, 118, 246, 412, 158, 149, 219, 158, 146, 214, 452, 263, 211, 218, 50, 233, 144, 113, 329, 190, 481, 142, -1, 50, 129, 219, -1, 83, -1, 78, 57, 123, -1, 102, -1, 111, -1, 90, 50, 478, 277, 203, 83, 371, 193, 275, 55, -1, 165, 50, 636, -1, 65, 282, 381, 77, 147, 133, 195, 342, 362, 50, 117, -1, -1, 265, 120, -1, 67, 431, 580, 137, -1, 179, 523, 110, 91, 226, 181, 121, -1, 205, 149, 232, 204, -1, -1, 182, 350, 195, 123, 210, 82, 293, 455, 119, 388, 115, 192, 247, 216, 180, 522, 50, 58, 50, 523, 157, 94, 196, 133, 110, 72, 112, -1, 243, 554, 125, 129, 364, 94, -1, 194, 114, -1, 190, 304, 55, 73, 79, 115, 152, 86, 238, 82, 166, 50, -1, -1, 331, 111, 306, 639, 121, 166, -1, 345, 174, 175, 94, 219, 365, 149, 97, 55, 556, 64, 136, 588, 147, 132, 164, 96, 115, 240, 56, 428, 117, 155, 122, 66, -1, 783, 128, 129, 128, 273, 160, 75, -1, 321, 396, 338, -1, 209, 151, 172, 110, 101, 218, 93, 211, 129, -1, 842, 231, 255, 171, 137, 208, 194, 547, -1, 299, 103, 278, -1, 97, 254, -1, -1, 122, 176, 179, 277, 307, 50, 115, 237, 91, -1, 113, -1, 54, 80, 288, 107, -1, 135, 228, 59, 273, 51, 169, 319, 50, 203, 144, 201, 160, 413, 122, 350, 217, 68, 51, 80, 747, 62, 200, -1, 345, 260, 84, 121, 50, 407, 145, 158, 50, -1, 170, 74, 335, 115, 113, 574, 325, 54, 114, 329, 169, 58, 164, 203, 199, 271, 74, 50, 59, -1, 66, 224, 132, 68, -1, 233, -1, 109, 350, -1, 183, 61, 59, 123, 207, 365, 286, 327, 57, 175, 309, -1, 231, 205, 278, 120, 134, 167, 323, 402, -1, 120, 113, -1, 358, -1, 50, 397, 179, -1, 120, -1, 67, 228, 323, 240, 212, 50, 65, 100, 123, 233, 202, 123, 118, 234, -1, -1, 301, 140, 138, 328, 288, 121, 218, 91, 185, 65, 339, 210, 970, 51, 93, 218, 217, 72, 168, 138, 261, 158, 193, 61, 92, -1, -1, 785, 352, 76, 421, -1, 438, 90, 182, 360, 88, -1, 283, 117, 82, 123, -1, -1, 317, -1, 50, 104, 257, 144, 68, 54, 135, 702, 105, 373, 171, -1, 93, 432, 168, 144, 225, 66, 339, 296, 163, 50, -1, 209, 309, 209, 131, 57, 143, 326, 175, 258, 158, -1, -1, 54, 124, 191, 145, 108, 146, 166, 53, 163, 154, 470, 50, 99, -1, 83, 280, 57, -1, -1, 412, 337, 326, -1, 194, 154, 112, 251, -1, 193, 56, 124, 507, 345, 122, 193, 334, 299, 60, -1, 181, -1, 369, 99, 119, 114, 142, 272, 105, 50, 149, 228, 111, 121, 116, 254, 220, 210, 351, 173, 167, 108, 92, -1, -1, 165, 200, 132, 411, 116, 209, 65, 53, 97, 182, 230, 62, 677, 304, -1, 112, 275, 120, 69, 142, 141, 140, 377, 580, 239, 244, 333, 140, 173, 313, -1, 819, 332, 205, 138, 316, 116, -1, 216, 468, 155, 79, -1, 255, -1, 110, 103, 250, 89, 69, 372, 50, 160, 162, 158, 294, 54, 693, 293, -1, 351, 51, 67, 217, 135, 165, 52, 682, 290, -1, 651, 147, 291, 210, 275, 61, 73, -1, 50, 314, 154, 50, 201, 145, 353, 94, 625, 245, 148, -1, 218, 79, 458, 159, 66, 71, 71, -1, 241, 177, 176, 112, 439, 177, 268, 114, 328, 542, 160, 236, 159, 226, -1, 267, 58, 385, 96, -1, 50, 117, 190, 166, 54, 321, 70, -1, 171, 95, 160, 153, -1, 159, 157, -1, 478, 300, 107, 117, 247, 80, 50, 67, 445, -1, 58, -1, 71, 365, 79, 247, -1, 394, 387, 169, 50, 162, 331, 378, 93, 460, 67, 160, -1, -1, 79, 132, 83, 302, 111, 257, 145, 112, 125, 477, 68, 199, 105, 120, 130, 168, 215, 154, 76, 281, 434, 303, 147, 670, 541, 112, 173, 307, 181, -1, 74, 277, 281, 112, 51, 728, 122, 59, -1, -1, 205, 100, 99, 171, -1, 50, 50, 145, -1, -1, 361, 129, 124, 69, 326, 230, 282, -1, 676, 259, 387, -1, 216, 52, 580, -1, 236, 462, 109, 50, 85, 65, -1, 182, 159, 188, 109, 98, 802, 93, -1, -1, 152, 443, 125, 366, 230, -1, 209, 266, -1, 115, 221, 386, 104, 61, 455, 127, -1, 146, 59, 411, 527, 72, 134, 120, 99, 177, 119, 304, 83, 115, -1, 293, 173, 391, 72, 91, 434, 147, 73, -1, -1, -1, -1, 201, 56, 464, 143, 196, 438, 137, 77, -1, 123, 143, -1, 110, 62, 122, 133, 68, 482, 271, 421, 127, 77, 72, 106, 292, 214, -1, 253, -1, 156, 160, 163, 148, 361, 534, -1, 87, 290, 89, 144, -1, 405, 267, -1, 254, 120, 80, 390, 181, 343, 290, 794, 91, 203, 374, 275, 114, 102, -1, 142, 125, -1, 50, 202, 155, 99, 188, 200, 61, -1, 339, 527, 84, 86, 116, -1, -1, 488, 158, 111, 50, 133, 204, 106, 105, 88, 91, -1, 99, 82, 423, 222, 204, 219, 54, 315, 322, 55, 105, 555, 163, -1, 145, 197, 124, 192, 131, 91, 98, 346, 559, 117, 435, 59, 105, -1, 113, 129, 195, 157, 50, 388, 238, 661, 157, 112, 134, 251, 130, 210, 51, 267, 159, 359, 555, 52, 149, 50, 146, 142, 98, 52, 267, 50, -1, 289, 232, 120, 257, 230, 332, 460, 137, 83, 137, 238, 156, 237, -1, 236, 132, 89, 510, 111, 226, 88, 62, 138, 342, 191, 209, 178, 230, -1, 129, 323, 343, 97, 353, -1, 125, 93, 324, 172, 171, 62, 98, 214, -1, 364, 108, 147, 282, 299, 50, 372, 316, 105, 176, 120, 54, 152, 87, 176, 330, 126, 81, -1, 277, 56, 112, 313, 654, 292, 50, 225, 401, 69, -1, -1, 122, 130, 56, 321, 164, 544, 183, 105, 296, 254, 148, 327, 149, 210, -1, -1, -1, 186, -1, 119, 501, -1, -1, 429, 78, 145, 159, 87, 150, -1, 180, 149, 355, -1, 244, 94, 496, 490, 231, 188, 256, 127, 145, 637, 305, 348, 241, 128, -1, 288, -1, 53, 165, 200, 92, -1, 401, -1, 288, 50, 221, 346, -1, 117, 121, 295, 202, 195, 672, 296, 129, 121, -1, 166, 445, 86, 100, 115, 78, 159, 273, 122, 247, 125, -1, -1, 349, 405, 583, 83, 67, 82, 99, 233, 212, 323, 289, 135, 707, 105, 319, 124, 187, 294, 106, 248, 249, -1, 120, 78, 174, 57, 380, -1, 212, 161, 371, -1, -1, 98, 215, 119, -1, 135, 282, 147, 330, 97, 69, 155, 75, -1, 148, 61, 130, 91, 418, 61, -1, 115, -1, 416, 311, 576, -1, 139, -1, 111, -1, -1, 409, 138, 369, 212, -1, 220, 162, 52, 256, 315, 79, 116, 144, 276, 466, 587, 244, 173, -1, 122, 76, 96, 427, 160, 178, 50, 379, -1, 50, 235, 303, 370, 341, 142, 417, 261, 147, 120, 80, 256, 85, 158, 119, -1, 244, 69, 181, 235, 622, 417, 275, 329, 53, 283, 187, 311, 229, 50, -1, 107, 734, 81, -1, 155, 305, 260, 528, 321, -1, 50, 66, 132, 196, 85, -1, 251, 86, 150, 98, -1, 203, 75, 144, 168, -1, 393, 67, 50, 203, -1, 97, 52, -1, 171, 127, 55, -1, 99, -1, 127, 796, 518, 64, 128, 124, 497, 50, 61, 134, 129, -1, 96, 352, 181, 184, -1, 134, 139, 273, 492, 50, 155, 113, 246, 265, -1, 296, 158, 99, 111, 168, 249, 75, 79, 143, 86, 91, -1, 151, 98, 73, 123, 286, 153, 450, 130, 80, 257, 50, 104, -1, 114, 131, 253, 454, 714, 160, 406, -1, -1, 186, 94, 156, 112, -1, 240, 381, 68, -1, 473, 89, 68, 271, 94, 287, 405, 394, 360, 205, 264, 104, 312, -1, 191, 104, -1, 297, 225, 421, 56, 51, 68, 580, 301, 181, 235, 183, 137, 354, -1, 84, 484, 136, 50, -1, 190, -1, 87, 126, 69, 126, 525, -1, 139, -1, 180, 427, 50, 113, 223, 103, 127, 117, 57, -1, -1, 51, -1, 443, 345, 362, 187, 241, 499, 190, 75, 517, 90, 264, 221, 640, 129, 67, 260, 57, 62, 567, 417, 183, 241, 280, 62, 156, 103, 160, 433, 264, 51, 59, 220, 230, 174, 504, 160, 125, 223, -1, 76, 106, 224, 168, -1, 224, 124, 54, 150, 365, 75, 150, 76, 533, -1, 165, 253, 68, 819, 134, 66, 60, 301, -1, 184, 108, 84, -1, -1, 223, 97, -1, -1, 76, 359, 200, 698, -1, 360, 543, 104, 279, 708, 146, 89, 401, 146, 131, 534, 446, 312, 73, 344, 185, 178, 60, 477, 554, 175, 50, 54, 196, 322, 152, 61, -1, 124, 137, -1, 217, 389, -1, -1, 53, 163, 51, 678, 208, -1, 109, 217, 127, 323, 77, 106, 556, 409, 367, 179, 67, 55, 216, 99, 535, 169, 122, 376, 274, 253, 75, 98, 60, 594, -1, 59, 285, 198, 260, 293, -1, 396, 176, 97, -1, 357, 225, -1, 371, 103, 161, 151, 219, 122, -1, 52, 56, 736, 162, -1, 342, 129, 94, 87, 95, 334, 118, 110, 117, 107, 56, 337, 310, 93, 268, 317, 493, 335, 201, 110, 355, 95, 70, 159, 105, 197, 112, 67, 317, 183, -1, 120, 636, 214, 327, 524, 201, 464, -1, 67, 221, 227, 72, 135, 143, 240, 165, 135, 108, 50, 161, 223, 75, 114, 379, 98, -1, -1, -1, -1, 125, 411, 217, 68, 80, 128, 550, 77, 139, 331, 186, 129, 86, 298, 149, 106, 310, 474, 80, 355, 197, 82, 229, 379, 50, 369, 187, 67, 127, 285, 132, 134, 141, 198, 429, 286, 304, 205, -1, -1, 797, 198, 158, 63, 109, 122, 281, 101, 279, -1, 57, 188, -1, 153, 205, 106, 119, 387, 131, 188, 221, -1, -1, -1, 287, 339, 206, 202, 54, 174, 296, 81, 250, -1, 181, -1, 208, 446, 195, 98, 255, 156, -1, 120, 103, 132, 124, -1, 163, 214, 147, 538, 134, 323, 173, 103, 162, 67, 253, 513, 480, 54, 368, 50, 105, 431, 150, -1, 508, 140, 50, 53, -1, 143, 423, 372, 259, 60, -1, -1, 58, 721, 77, 192, -1, 90, 217, 102, 50, 164, 159, 169, 329, -1, 210, 255, 66, 159, 105, 320, 75, 270, 673, 146, 111, 89, 764, 135, -1, 481, 113, 163, 262, 250, 128, 586, 128, 241, -1, 125, 153, 248, 50, 159, 408, 76, 603, -1, 123, 481, -1, 154, 405, 169, 212, 100, 330, -1, 197, -1, 143, 160, 156, 212, 51, 191, 122, 139, 75, 104, 168, 255, 289, 249, 268, 77, 387, 121, 118, 88, 271, 109, 59, -1, -1, 51, 74, 341, 170, 138, 105, 235, 709, 78, 142, 226, 87, -1, 309, 276, 103, -1, 86, 340, 470, 50, 198, 119, 205, 167, 76, 389, 126, 559, 172, 100, 297, 158, 120, 69, 62, -1, 95, 195, 146, 293, -1, 283, 269, 86, 108, 77, 97, 102, 259, 177, 129, 490, 117, -1, 397, -1, -1, 201, 141, 272, 452, 271, 146, 117, -1, 332, 65, 83, 322, 133, 50, -1, 214, 124, -1, 173, 54, -1, 265, 125, -1, 106, 137, 50, 608, 375, 251, 60, 169, 626, 136, 123, -1, 102, 284, 80, -1, 180, -1, 335, -1, -1, 380, 334, -1, 242, 135, -1, 50, 135, 174, 238, 224, 140, 208, 76, 469, 217, 122, 121, 204, 167, -1, 205, 143, 275, 162, 134, 214, -1, 261, 126, 521, 98, -1, 429, 168, 112, 75, 323, 50, -1, 377, 287, 351, 107, 195, 346, 89, 394, 54, 362, 215, 116, 155, 59, 75, 63, 250, 246, 103, 89, 54, 141, 140, 55, 171, 277, 355, 145, -1, 57, 50, 119, 256, 132, 318, 50, -1, 257, 431, -1, 69, 241, 249, 70, 248, 158, 508, 232, 322, 114, 63, 447, 114, 88, -1, 122, 154, 289, 179, 178, 182, 70, -1, 233, -1, 140, -1, 110, 351, 233, 651, 258, 106, -1, 552, 177, 191, -1, 387, 128, 62, 226, 50, 59, -1, 82, 111, 127, 160, 292, 130, 93, 165, 183, 75, 65, 515, 472, 161, 113, 336, -1, -1, -1, -1, 60, 119, 159, 54, 86, 208, 158, 405, 314, 171, 207, -1, 379, 195, 138, -1, 503, 242, 55, 191, 407, 345, 81, 65, 122, 145, 215, 200, 293, 91, 174, 362, 380, -1, 73, 76, 182, 428, 243, 237, 139, -1, 132, 237, 238, 63, 148, -1, 383, 56, 359, 231, 586, 162, 50, -1, 269, 276, 142, 169, -1, 113, 94, 229, 223, 188, -1, 128, 195, 481, 88, 123, 119, -1, 137, 244, -1, 68, 301, 77, 246, 401, -1, 348, 287, 448, -1, 186, 65, 425, 263, 73, 165, 166, 93, 104, 149, -1, 214, 190, 78, 143, 102, 264, -1, 60, 396, 197, 202, 335, 118, 356, -1, 144, 83, 169, 213, -1, 84, 176, 152, 176, 310, 262, 335, 391, -1, 713, 184, -1, 124, 59, 133, 158, 234, 182, 236, 498, 226, 182, 316, 139, 109, 155, 71, 102, 170, 218, 54, 533, -1, 50, 97, 425, 128, -1, 169, 141, 110, 357, 267, 521, 128, 340, 278, 232, 133, 126, 166, 141, -1, 77, 194, 51, 128, 108, -1, 162, 371, 62, 77, 142, 264, 190, 108, 321, 127, 224, 50, 62, 50, 583, 422, -1, 189, -1, 213, 137, -1, 141, -1, 572, 299, 103, -1, 577, 228, 50, 190, 74, 280, 369, 237, 286, 225, 118, 88, 176, 285, 617, 112, 241, 247, 55, 115, 158, 405, 70, 679, -1, 67, 77, 114, 179, 111, 79, 88, 211, 250, 155, -1, 535, -1, 124, 124, 413, 220, 118, 662, 66, 270, 179, 164, 204, 127, 193, 135, 264, 100, 174, 241, 95, 123, 89, 69, -1, 61, 244, 50, 77, 85, 146, 51, 205, 401, 186, 108, 221, -1, 411, 131, 330, 137, 81, 146, 638, 166, 176, -1, 343, 152, -1, 61, -1, 316, 200, 57, 100, 229, -1, 60, 233, 53, 435, 374, 471, 119, 454, 78, -1, 413, 61, 55, 200, 270, 131, 251, -1, 343, 70, 106, 363, 67, -1, 199, 494, 220, 143, 241, 291, 166, 400, 381, 124, 50, 75, 167, 124, 204, 335, 232, 237, 324, 346, 153, 121, 106, 129, 216, 219, 193, 80, 82, -1, 300, 56, 96, 198, 68, 182, 136, 149, 166, 114, 145, -1, 140, 78, 52, 105, 389, 636, 199, 431, 324, 96, 165, 260, 443, 313, -1, 83, 141, 371, 132, 117, 289, 266, 198, 66, -1, 130, -1, 219, 218, 129, 330, 119, 155, 122, 118, 361, 265, 52, 219, 128, 181, -1, 435, 320, 252, 346, 149, -1, 373, 217, 71, 125, 147, 392, 198, 159, -1, 57, -1, -1, 265, 77, -1, 224, -1, 353, 176, 437, 461, 70, 595, 498, -1, 108, 596, 272, 305, 133, 62, 301, 114, 240, 138, 108, -1, 276, 139, 101, 213, -1, 60, 164, 189, 341, 251, 123, 393, 57, 183, 85, 221, 341, 235, 113, -1, 634, 111, -1, 50, 396, 81, 347, 175, 164, 131, 57, 108, 50, 372, 122, 62, 396, 203, 112, -1, 138, 162, 50, 537, 50, 97, 416, 465, 66, 117, 166, 224, 57, 278, 181, 490, 138, 112, -1, 315, 142, 118, 369, 218, 254, 259, 236, 63, 523, 780, 52, 391, -1, 256, 110, 201, 69, 236, 236, 437, -1, 522, 132, 213, 114, 323, 396, 77, 132, 280, -1, 50, 212, 319, 392, 50, -1, 133, 103, 178, 187, 168, 159, 179, -1, -1, 242, 79, 247, 58, -1, 179, 245, 105, 50, 95, 112, 593, 141, 337, 188, 153, 184, 125, 283, 176, 230, 232, 307, 444, 205, 168, -1, -1, 269, 129, 404, 455, 317, 153, 214, 107, 138, 333, 410, 314, 152, 90, 166, 126, 170, 257, 99, 101, 178, 84, 172, 125, 95, -1, 306, 397, 52, 160, 102, 71, -1, -1, -1, 423, 298, 140, 191, 256, 258, 60, 351, 133, 170, 60, 166, 138, 293, 124, 600, 102, 258, 280, -1, 353, 328, 618, 63, 330, 98, 219, 407, -1, 177, 114, 60, 576, 286, 293, 147, 322, 176, 313, 287, 181, 202, -1, 175, 198, 665, 271, 178, 80, 242, 171, 50, 67, 50, 139, 107, 122, 368, 149, 217, -1, 459, 157, 155, -1, 193, 74, 233, 96, 155, 215, 198, 240, 92, 119, -1, 226, -1, 86, 237, 229, 199, -1, 61, 251, -1, 211, 112, 153, 58, 212, 319, 410, 526, -1, 110, 65, 109, 168, 290, 104, 322, 55, 112, 173, 184, 53, 137, 149, 170, 402, 50, 112, -1, 501, 138, 194, 57, 178, -1, -1, 72, 101, 234, -1, 422, 356, 78, 237, 184, 159, 50, 345, 270, 554, 398, 75, -1, 99, 103, -1, -1, 130, -1, 138, 290, -1, 79, 127, 134, 260, 155, 474, 355, 70, 205, 194, 300, 322, 347, 124, 120, 136, -1, 201, 166, 65, 462, 242, -1, 205, 50, 111, 364, 191, 425, 407, 329, 50, 297, 103, 214, 361, 573, 105, 299, 317, 252, 90, 66, 71, 119, -1, 93, 136, 286, 359, 85, 103, 928, 259, 75, 187, 79, 235, 339, 73, 261, 188, 555, 286, 201, 145, 380, -1, -1, -1, -1, 62, 203, 158, 66, -1, 125, 109, 62, 364, -1, 62, 331, -1, 180, 55, 66, 174, 111, 358, 451, 243, 470, 408, -1, 190, 151, -1, 58, 680, 112, 297, 64, 225, 96, 117, 268, 102, 467, 297, 219, 59, 118, 250, 184, 351, 69, 252, 56, -1, -1, 438, 178, -1, 187, 399, 142, 55, -1, 116, 567, 99, 52, 99, 198, 333, 218, 232, 270, 147, 190, 263, 288, 399, 230, 62, 455, 281, 131, 284, -1, 157, 323, 126, -1, 86, -1, 286, 309, 230, 151, 98, 339, 255, 135, 271, 150, 237, -1, 63, 81, 86, 63, 79, 217, 591, 529, 186, 52, 199, 727, -1, 103, 150, 77, 221, 71, 420, 375, 155, 207, 166, 89, 75, 78, 218, 150, 188, 107, 53, 101, 161, 138, 153, 195, 244, 157, 417, 114, 192, -1, 175, 278, -1, 590, -1, 211, 151, 151, 108, 189, 96, 194, 56, 335, 138, 51, 519, 139, 82, 121, 316, 338, 196, 99, 95, 96, 200, 271, 237, 359, 286, 71, 548, 315, 196, -1, 91, -1, 51, 63, 714, 84, 107, 525, 439, 329, -1, 199, 55, 228, 147, -1, 134, 509, 82, 50, 279, 216, 116, 174, 62, 243, 82, -1, 52, -1, 257, 88, 50, 233, -1, 67, 300, -1, 377, 168, 118, 120, 109, 253, 100, 121, 144, 166, 315, 111, 80, 276, 161, 158, 642, 67, -1, 390, 272, 216, -1, -1, 145, 508, 93, -1, 130, 51, 133, -1, -1, 163, 318, 173, -1, 82, 203, 328, 369, 594, 143, -1, -1, 58, 89, 90, 329, 141, 411, 97, 184, 50, 86, 131, 58, 175, 66, 220, 221, 164, 58, 98, -1, 200, -1, 228, 157, 73, -1, 50, 495, 362, 50, 66, 179, 50, 305, 736, 165, 207, 662, 100, 58, 397, 443, 372, 248, 125, 111, 77, 179, 368, -1, 261, 265, 70, 174, 272, 438, 199, 303, 117, 120, 242, 123, -1, 339, 169, 891, 285, 521, 137, 282, 378, 268, 179, 112, 185, 62, 361, -1, 241, 621, 87, 65, 474, 172, 57, 98, 646, 165, 149, 445, 201, 382, 73, 482, 142, 137, -1, 72, 246, 479, -1, 238, 176, 292, 199, 279, 316, 154, 233, 201, 214, 67, 257, 179, 112, 192, 88, -1, -1, 66, -1, -1, 400, 173, -1, -1, 160, 131, -1, 79, 135, -1, 567, 53, 325, 58, 168, 183, 174, -1, 84, 201, -1, 78, 525, 117, 307, 286, 210, 379, 217, 210, -1, 185, 446, 50, 56, -1, 434, 211, 171, 142, 489, 77, 601, 81, 132, 50, 108, 102, 93, 157, 161, 188, 130, -1, 140, 108, 58, 132, 89, -1, 210, -1, 91, 602, 600, 179, 354, 92, 125, 217, 371, 91, 337, 114, 194, 61, 56, 113, 55, 405, 409, -1, 92, 188, 324, 94, 72, 393, 497, 228, 83, -1, -1, 402, -1, 444, 126, -1, 278, -1, 555, 257, 368, 132, 192, 139, 388, 572, 579, 127, 551, 350, 365, 51, -1, 183, 125, 114, 114, 56, 148, 112, 428, 436, 150, 227, 243, 242, 269, 310, 572, 90, 113, 237, 86, 194, -1, 66, 131, 206, 135, 187, 187, -1, 66, 115, 328, -1, 118, 75, 76, -1, 50, 153, 58, 108, -1, 271, 233, 300, 51, 91, -1, 736, 281, -1, 271, 50, -1, 91, 142, 247, 467, 191, 304, 395, 50, 259, 480, 189, 297, -1, 67, 288, 312, 533, 152, 110, 668, 266, 135, 107, 172, 61, 302, 146, 170, 61, 51, 148, 298, 427, 122, 63, 87, 166, 110, 132, 237, 258, 63, 160, 56, 284, 148, 666, 345, 172, -1, 135, 165, 502, 772, 50, 188, 100, -1, 222, 137, 82, 87, 291, -1, 284, -1, 171, -1, -1, 160, 237, 286, 90, 415, 166, 95, 109, 235, 137, 50, 168, 173, 200, 51, 81, 79, 320, 167, 356, 61, 175, 123, 100, 141, 50, -1, 229, 141, 382, 137, 60, 329, 719, -1, 208, -1, 484, 72, 139, 111, 215, 80, 138, -1, 285, 283, 402, 227, 375, -1, 220, -1, 51, 183, 109, 70, 237, 112, 69, 337, 173, -1, 351, 411, 234, 84, 546, 61, 96, 208, 163, 313, 78, 57, 223, 307, 63, 345, 452, 321, 213, 357, 102, 260, 131, 62, 296, 50, -1, 90, 124, 196, 112, 81, 267, 495, 65, 168, 152, 173, 129, 601, 198, 433, 150, 99, 701, 184, 50, 149, -1, 75, 434, -1, 240, 165, -1, 117, 141, -1, 573, 393, 268, 58, 436, -1, 50, 210, -1, 152, 233, 216, 284, 53, 153, -1, 51, 268, 272, 451, 74, 71, 116, 50, 85, 299, 285, 194, 267, 167, 136, 54, 103, 73, -1, 50, 115, -1, 557, 475, 50, 50, 88, 171, 880, 555, 252, 288, -1, 114, 353, 101, 65, 80, 214, -1, -1, -1, 128, -1, 541, 338, 304, 138, 187, 312, 118, 127, 157, 150, 126, 460, 217, 97, 468, 104, 56, 169, -1, 354, 74, 568, 232, 262, -1, 52, 79, 106, 144, 149, 102, 276, 204, 172, 114, 137, 322, 664, 187, 55, 50, 300, 113, 106, 296, 110, 208, 121, 78, 407, 506, 62, 114, 124, 260, 58, 346, 450, -1, 276, 319, 185, -1, 98, 137, -1, 328, 110, 143, 107, 99, 59, 79, 268, 77, 182, 216, 134, 156, -1, 100, -1, 439, 158, 113, 297, 299, 123, 277, 243, 53, 204, 142, 205, 253, 463, 53, 115, 83, 130, 224, 61, 290, -1, 387, 110, 534, 280, 205, -1, -1, 129, 150, -1, 262].\n"
     ]
    }
   ],
   "source": [
    "from ocpdet import CUSUM\n",
    "import numpy as np\n",
    "\n",
    "np.random.seed(3141592) \n",
    "\n",
    "# User-defined parameters\n",
    "window_size = 50 # Burn-in size of the window for CUSUM\n",
    "thresh = 7.5 # Threshold for CUSUM\n",
    "num_sequences = 10000 # Number of sequences to generate\n",
    "max_duration = 1000 # Maximum duration of each sequence with variable length\n",
    "min_duration = 100 # Minimum duration of each sequence with variable length\n",
    "\n",
    "# Inference (detecting change points)\n",
    "ls_changepoints = []\n",
    "ls_durations = []\n",
    "ls_predictions = []\n",
    "for _ in range(num_sequences):\n",
    "    # Randomly generate the duration of the sequence\n",
    "    it_duration = np.random.randint(min_duration, max_duration) + 1\n",
    "    ls_durations.append(it_duration)\n",
    "\n",
    "    # Randomly decide whether to have a changepoint or not\n",
    "    # If no changepoint, set it to infinity (no change)\n",
    "    # If there is a changepoint, randomly select its position\n",
    "    flag_no_change = np.random.choice([True, False], p=[0.5, 0.5])\n",
    "    if flag_no_change:\n",
    "        it_changepoint = np.inf\n",
    "    else:\n",
    "        it_changepoint = np.random.randint(min_duration, it_duration)\n",
    "    ls_changepoints.append(it_changepoint)\n",
    "\n",
    "    # Generate sequence data\n",
    "    if it_changepoint == np.inf:\n",
    "        # No change, generate data from a single distribution\n",
    "        data = np.random.normal(loc=0., scale=0.1, size=(it_duration,))\n",
    "    else:\n",
    "        # Change at it_changepoint, generate data from two distributions\n",
    "        data = np.concatenate([\n",
    "            np.random.normal(loc=0., scale=0.1, size=(it_changepoint,)),\n",
    "            np.random.normal(loc=0.1, scale=0.1, size=(it_duration - it_changepoint,))\n",
    "        ])\n",
    "\n",
    "    # Process the data with CUSUM\n",
    "    model = CUSUM(h=thresh, burnin=window_size, mu=0., sigma=0.1)\n",
    "    model.process(data)\n",
    "    preds = model.changepoints\n",
    "    if len(preds) > 0:\n",
    "        it_pred = preds[0]\n",
    "    else:\n",
    "        it_pred = - 1 \n",
    "    ls_predictions.append(it_pred)\n",
    "\n",
    "# Output results\n",
    "print(f\"Generated {num_sequences} sequences with variable lengths.\")\n",
    "print(f\"Average duration of sequences: {np.mean(ls_durations):.2f}\")\n",
    "print(f\"Average changepoint position: {np.mean(ls_changepoints):.2f}.\")\n",
    "print(f\"Average predicted changepoint position: {np.mean(ls_predictions):.2f}.\")\n",
    "print(f\"Durations: {ls_durations}.\")\n",
    "print(f\"Detected changepoints: {ls_changepoints}.\")\n",
    "print(f\"Predicted change points: {ls_predictions}.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "34862880",
   "metadata": {},
   "source": [
    "### Note\n",
    "- Now we have `ls_changepoints` (changepoint indices: 0-based), `ls_durations` (sequence lengths: 1-based), and `ls_predictions` (detection indices: 0-based). They will be used to compute the KME-ARL and KME-ADD.\n",
    "- Changepoints in `ls_changepoints`  must set to inf if a sequence does not have a changepoint.\n",
    "- Predictions (detected points) in `ls_predictions` must set to -1 if no changepoint was detected."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4db779ab",
   "metadata": {},
   "source": [
    "# 2. Compute ARL\n",
    "We first compute significantly biased ARL (called LB-ARL in our paper)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a0bd5ae2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "#samples:                   10000\n",
      "#overruns:                  1284\n",
      "#samples for computing ARL: 3845\n",
      "ARL±SE:                     224.49518855656697 ± 2.6516159843544163\n"
     ]
    }
   ],
   "source": [
    "from quick_start_toolkit import calc_naive_ARL\n",
    "\n",
    "naiARL, naisterr, naieffective_num_samples = calc_naive_ARL(\n",
    "    ls_predictions, ls_changepoints, flag_less_biased=True, flag_verbose=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a40b5a3e",
   "metadata": {},
   "source": [
    "`#overruns` means the number of sequences without a detection point, which are not used for computing the LB-ARL and cause unstable and biased estimation.\n",
    "\n",
    "We next compute our proposed KME-ARL. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3bd76a96",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "KME-ARL: 303.2259523829064 +/- 2.373468080805263\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\chopi\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.11_qbz5n2kfra8p0\\LocalCache\\local-packages\\Python311\\site-packages\\lifelines\\utils\\__init__.py:320: IntegrationWarning: The maximum number of subdivisions (50) has been achieved.\n",
      "  If increasing the limit yields no improvement it is advised to analyze \n",
      "  the integrand in order to determine the difficulties.  If the position of a \n",
      "  local difficulty can be determined (singularity, discontinuity) one will \n",
      "  probably gain from splitting up the interval and calling the integrator \n",
      "  on the subranges.  Perhaps a special-purpose integrator should be used.\n",
      "  return 2 * quad(lambda tau: (tau * model.predict(tau)), 0, t, epsabs=1.49e-10, epsrel=1e-10)[0]\n"
     ]
    }
   ],
   "source": [
    "from quick_start_toolkit import calc_KME\n",
    "\n",
    "kmeARL, kmesterr, kmeeffective_num_samples = calc_KME(\n",
    "    ls_predictions, ls_changepoints, duration=None, duration_array=ls_durations, flag_verbose=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6806dfc0",
   "metadata": {},
   "source": [
    "This is much closer to the true ARL $ 310.97  +/- 2.63$.\n",
    "\n",
    "### Note\n",
    "- `duration` variable is used only when the sequence length is constant; otherwise, set to None, and use `duratoin_array`.\n",
    "- Please ignore `InregrationWarning`, which `scipy.integrate.quad` in `lifelines` consistently arises."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e606176e",
   "metadata": {},
   "source": [
    "# 3. Compute ADD\n",
    "We next compute the ADD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1e040fe0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "#samples:                   10000\n",
      "#no alarm samples:          1284\n",
      "#samples for computing ADD: 2078\n",
      "ADD±SE:                     8.81087584215592 ± 0.10589145201356658\n"
     ]
    }
   ],
   "source": [
    "from quick_start_toolkit import calc_naive_ADD\n",
    "\n",
    "naiADD, sterr, effective_num_samples = calc_naive_ADD(\n",
    "    ls_predictions, ls_changepoints, flag_verbose=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "9b66d26e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "KME-ADD: 8.952077670956232 +/- 0.10377192380451099\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\chopi\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.11_qbz5n2kfra8p0\\LocalCache\\local-packages\\Python311\\site-packages\\lifelines\\utils\\__init__.py:320: IntegrationWarning: The maximum number of subdivisions (50) has been achieved.\n",
      "  If increasing the limit yields no improvement it is advised to analyze \n",
      "  the integrand in order to determine the difficulties.  If the position of a \n",
      "  local difficulty can be determined (singularity, discontinuity) one will \n",
      "  probably gain from splitting up the interval and calling the integrator \n",
      "  on the subranges.  Perhaps a special-purpose integrator should be used.\n",
      "  return 2 * quad(lambda tau: (tau * model.predict(tau)), 0, t, epsabs=1.49e-10, epsrel=1e-10)[0]\n"
     ]
    }
   ],
   "source": [
    "from quick_start_toolkit import calc_KME_ADD\n",
    "\n",
    "kmeADD, kmesterr, kmeeffective_num_samples = calc_KME_ADD(\n",
    "    ls_predictions, ls_changepoints, duration=None, duration_array=ls_durations, flag_verbose=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "560c67a6",
   "metadata": {},
   "source": [
    "### Note\n",
    "- `duration` variable is used only when the sequence length is constant; otherwise, set to None, and use `duratoin_array`.\n",
    "- Please ignore `InregrationWarning`, which `scipy.integrate.quad` in `lifelines` consistently arises."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3c834358",
   "metadata": {},
   "source": [
    "# Appendix: ARL-ADD Tradeoff Curve\n",
    "Let's plot ARL-ADD tradeoff curves."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5a210d29",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing with threshold: 4.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\chopi\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.11_qbz5n2kfra8p0\\LocalCache\\local-packages\\Python311\\site-packages\\lifelines\\utils\\__init__.py:320: IntegrationWarning: The maximum number of subdivisions (50) has been achieved.\n",
      "  If increasing the limit yields no improvement it is advised to analyze \n",
      "  the integrand in order to determine the difficulties.  If the position of a \n",
      "  local difficulty can be determined (singularity, discontinuity) one will \n",
      "  probably gain from splitting up the interval and calling the integrator \n",
      "  on the subranges.  Perhaps a special-purpose integrator should be used.\n",
      "  return 2 * quad(lambda tau: (tau * model.predict(tau)), 0, t, epsabs=1.49e-10, epsrel=1e-10)[0]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing with threshold: 8.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\chopi\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.11_qbz5n2kfra8p0\\LocalCache\\local-packages\\Python311\\site-packages\\lifelines\\utils\\__init__.py:320: IntegrationWarning: The maximum number of subdivisions (50) has been achieved.\n",
      "  If increasing the limit yields no improvement it is advised to analyze \n",
      "  the integrand in order to determine the difficulties.  If the position of a \n",
      "  local difficulty can be determined (singularity, discontinuity) one will \n",
      "  probably gain from splitting up the interval and calling the integrator \n",
      "  on the subranges.  Perhaps a special-purpose integrator should be used.\n",
      "  return 2 * quad(lambda tau: (tau * model.predict(tau)), 0, t, epsabs=1.49e-10, epsrel=1e-10)[0]\n",
      "C:\\Users\\chopi\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.11_qbz5n2kfra8p0\\LocalCache\\local-packages\\Python311\\site-packages\\lifelines\\utils\\__init__.py:320: IntegrationWarning: The maximum number of subdivisions (50) has been achieved.\n",
      "  If increasing the limit yields no improvement it is advised to analyze \n",
      "  the integrand in order to determine the difficulties.  If the position of a \n",
      "  local difficulty can be determined (singularity, discontinuity) one will \n",
      "  probably gain from splitting up the interval and calling the integrator \n",
      "  on the subranges.  Perhaps a special-purpose integrator should be used.\n",
      "  return 2 * quad(lambda tau: (tau * model.predict(tau)), 0, t, epsabs=1.49e-10, epsrel=1e-10)[0]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing with threshold: 12.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\chopi\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.11_qbz5n2kfra8p0\\LocalCache\\local-packages\\Python311\\site-packages\\lifelines\\utils\\__init__.py:320: IntegrationWarning: The maximum number of subdivisions (50) has been achieved.\n",
      "  If increasing the limit yields no improvement it is advised to analyze \n",
      "  the integrand in order to determine the difficulties.  If the position of a \n",
      "  local difficulty can be determined (singularity, discontinuity) one will \n",
      "  probably gain from splitting up the interval and calling the integrator \n",
      "  on the subranges.  Perhaps a special-purpose integrator should be used.\n",
      "  return 2 * quad(lambda tau: (tau * model.predict(tau)), 0, t, epsabs=1.49e-10, epsrel=1e-10)[0]\n",
      "C:\\Users\\chopi\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.11_qbz5n2kfra8p0\\LocalCache\\local-packages\\Python311\\site-packages\\lifelines\\utils\\__init__.py:320: IntegrationWarning: The maximum number of subdivisions (50) has been achieved.\n",
      "  If increasing the limit yields no improvement it is advised to analyze \n",
      "  the integrand in order to determine the difficulties.  If the position of a \n",
      "  local difficulty can be determined (singularity, discontinuity) one will \n",
      "  probably gain from splitting up the interval and calling the integrator \n",
      "  on the subranges.  Perhaps a special-purpose integrator should be used.\n",
      "  return 2 * quad(lambda tau: (tau * model.predict(tau)), 0, t, epsabs=1.49e-10, epsrel=1e-10)[0]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing with threshold: 16.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\chopi\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.11_qbz5n2kfra8p0\\LocalCache\\local-packages\\Python311\\site-packages\\lifelines\\utils\\__init__.py:320: IntegrationWarning: The maximum number of subdivisions (50) has been achieved.\n",
      "  If increasing the limit yields no improvement it is advised to analyze \n",
      "  the integrand in order to determine the difficulties.  If the position of a \n",
      "  local difficulty can be determined (singularity, discontinuity) one will \n",
      "  probably gain from splitting up the interval and calling the integrator \n",
      "  on the subranges.  Perhaps a special-purpose integrator should be used.\n",
      "  return 2 * quad(lambda tau: (tau * model.predict(tau)), 0, t, epsabs=1.49e-10, epsrel=1e-10)[0]\n",
      "C:\\Users\\chopi\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.11_qbz5n2kfra8p0\\LocalCache\\local-packages\\Python311\\site-packages\\lifelines\\utils\\__init__.py:320: IntegrationWarning: The maximum number of subdivisions (50) has been achieved.\n",
      "  If increasing the limit yields no improvement it is advised to analyze \n",
      "  the integrand in order to determine the difficulties.  If the position of a \n",
      "  local difficulty can be determined (singularity, discontinuity) one will \n",
      "  probably gain from splitting up the interval and calling the integrator \n",
      "  on the subranges.  Perhaps a special-purpose integrator should be used.\n",
      "  return 2 * quad(lambda tau: (tau * model.predict(tau)), 0, t, epsabs=1.49e-10, epsrel=1e-10)[0]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing with threshold: 20.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\chopi\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.11_qbz5n2kfra8p0\\LocalCache\\local-packages\\Python311\\site-packages\\lifelines\\utils\\__init__.py:320: IntegrationWarning: The maximum number of subdivisions (50) has been achieved.\n",
      "  If increasing the limit yields no improvement it is advised to analyze \n",
      "  the integrand in order to determine the difficulties.  If the position of a \n",
      "  local difficulty can be determined (singularity, discontinuity) one will \n",
      "  probably gain from splitting up the interval and calling the integrator \n",
      "  on the subranges.  Perhaps a special-purpose integrator should be used.\n",
      "  return 2 * quad(lambda tau: (tau * model.predict(tau)), 0, t, epsabs=1.49e-10, epsrel=1e-10)[0]\n"
     ]
    }
   ],
   "source": [
    "from ocpdet import CUSUM\n",
    "import numpy as np\n",
    "from quick_start_toolkit import calc_naive_ADD, calc_naive_ADD\n",
    "from quick_start_toolkit import calc_KME, calc_KME_ADD\n",
    "\n",
    "np.random.seed(3141592)  \n",
    "\n",
    "# User-defined parameters\n",
    "window_size = 50 # Burn-in size of the window for CUSUM\n",
    "num_sequences = 300 # Number of sequences to generate\n",
    "max_duration = 1000 # Maximum duration of each sequence with variable length\n",
    "min_duration = 100 # Minimum duration of each sequence with variable length\n",
    "ls_thresholds = [4., 8., 12., 16., 20.]  # Different thresholds to test\n",
    "\n",
    "# Start estimating ARL and ADD for different thresholds\n",
    "ls_LB_ARL = []\n",
    "ls_LB_ADD = []\n",
    "ls_KME_ARL = []\n",
    "ls_KME_ADD = []\n",
    "ls_LB_ARLerr = []\n",
    "ls_LB_ADDerr = []\n",
    "ls_KME_ARLerr = []\n",
    "ls_KME_ADDerr = []\n",
    "for thresh in ls_thresholds:\n",
    "    print(f\"Processing with threshold: {thresh}\")\n",
    "\n",
    "    # Inference (detecting change points)\n",
    "    ls_changepoints = []\n",
    "    ls_durations = []\n",
    "    ls_predictions = []\n",
    "    for _ in range(num_sequences):\n",
    "        # Randomly generate the duration of the sequence\n",
    "        it_duration = np.random.randint(min_duration, max_duration) + 1\n",
    "        ls_durations.append(it_duration)\n",
    "\n",
    "        # Randomly decide whether to have a changepoint or not\n",
    "        # If no changepoint, set it to infinity (no change)\n",
    "        # If there is a changepoint, randomly select its position\n",
    "        flag_no_change = np.random.choice([True, False], p=[0.5, 0.5])\n",
    "        if flag_no_change:\n",
    "            it_changepoint = np.inf\n",
    "        else:\n",
    "            it_changepoint = np.random.randint(min_duration, it_duration)\n",
    "        ls_changepoints.append(it_changepoint)\n",
    "\n",
    "        # Generate sequence data\n",
    "        if it_changepoint == np.inf:\n",
    "            # No change, generate data from a single distribution\n",
    "            data = np.random.normal(loc=0., scale=0.1, size=(it_duration,))\n",
    "        else:\n",
    "            # Change at it_changepoint, generate data from two distributions\n",
    "            data = np.concatenate([\n",
    "                np.random.normal(loc=0., scale=0.1, size=(it_changepoint,)),\n",
    "                np.random.normal(loc=0.1, scale=0.1, size=(it_duration - it_changepoint,))\n",
    "            ])\n",
    "\n",
    "        # Process the data with CUSUM\n",
    "        model = CUSUM(h=thresh, burnin=window_size, mu=0., sigma=0.1)\n",
    "        model.process(data)\n",
    "        preds = model.changepoints\n",
    "        if len(preds) > 0:\n",
    "            it_pred = preds[0]\n",
    "        else:\n",
    "            it_pred = - 1 \n",
    "        ls_predictions.append(it_pred)\n",
    "\n",
    "    # Compute ARL and ADD\n",
    "    naiARL, naisterr, naieffective_num_samples = calc_naive_ARL(\n",
    "        ls_predictions, ls_changepoints, flag_less_biased=True, flag_verbose=False)\n",
    "\n",
    "    kmeARL, kmesterr, kmeeffective_num_samples = calc_KME(\n",
    "        ls_predictions, ls_changepoints, duration=None, duration_array=ls_durations, flag_verbose=False)\n",
    "\n",
    "    naiADD, sterr, effective_num_samples = calc_naive_ADD(\n",
    "        ls_predictions, ls_changepoints, flag_verbose=False)\n",
    "\n",
    "    kmeADD, kmesterr, kmeeffective_num_samples = calc_KME_ADD(\n",
    "        ls_predictions, ls_changepoints, duration=None, duration_array=ls_durations, flag_verbose=False)\n",
    "    \n",
    "    # Store results\n",
    "    ls_LB_ARL.append(naiARL)\n",
    "    ls_LB_ADD.append(naiADD)\n",
    "    ls_KME_ARL.append(kmeARL)\n",
    "    ls_KME_ADD.append(kmeADD)\n",
    "    ls_LB_ARLerr.append(naisterr)\n",
    "    ls_LB_ADDerr.append(sterr)\n",
    "    ls_KME_ARLerr.append(kmesterr)\n",
    "    ls_KME_ADDerr.append(kmesterr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "27acad38",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAGGCAYAAADmRxfNAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB6Q0lEQVR4nO3dd3hUZdrH8e9MeichCQkQIDSVIlWaorA2ukoRUBRwV30VRMXeURR17bsqgqziwlBEcEVFBEXUtdDsiksLnYRASO8z5/3jMANhJpA+Kb/Pdc0155x5zpl7Mg/D3PM0i2EYBiIiIiIiIpVg9XYAIiIiIiJS9ymxEBERERGRSlNiISIiIiIilabEQkREREREKk2JhYiIiIiIVJoSCxERERERqTQlFiIiIiIiUmlKLEREREREpNKUWIiIiIiISKUpsRARkTpr9+7dWCwW5s+fX63Pk5KSwujRo2ncuDEWi4WXX34ZgO3bt3PZZZcRERGBxWLhP//5T7XGISJSmymxEBHx4PXXX8disdC7d+9Sy1gslhK38PBwLrroIj7++GO3svPnz8disbB58+YKx2S322natCkWi4VPPvnEY5kZM2aUiCk4OJgWLVowfPhw3n77bQoKCtzOmTRpUolzQkNDad26NaNHj2b58uU4HI4yxbdq1SpmzJhR4ddXm9155518+umnPPDAAyxYsIBBgwYBMHHiRH799VeeeuopFixYQM+ePb0cqYiI9/h6OwARkdrIZrPRqlUrNm7cyI4dO2jbtq3HcpdeeinXX389hmGwZ88eZs+ezfDhw/nkk0+4/PLLqzSmdevWcejQIVq1aoXNZmPw4MGllp09ezahoaEUFBRw4MABPv30U2644QZefvllPvroIxISEkqUDwgIYN68eQDk5eWxZ88ePvzwQ0aPHs2AAQP44IMPCA8PP218q1at4rXXXquXycW6deu44ooruPvuu13H8vLy+O6773jooYeYOnWqF6MTEakdlFiIiJwiKSmJb7/9lhUrVnDzzTdjs9l47LHHPJZt3749EyZMcO2PGjWKDh068Morr1R5YrFw4UK6d+/OxIkTefDBB8nJySEkJMRj2dGjRxMdHe3af/TRR7HZbFx//fWMGTOG77//vkR5X1/fEq8D4Mknn+SZZ57hgQce4MYbb2Tp0qVV9lqKi4txOBz4+/tX2TWr0+HDh2nUqFGJY6mpqQBux73ldPVBRKQmqCuUiMgpbDYbkZGRDB06lNGjR2Oz2cp87jnnnEN0dDQ7d+6s0pjy8vJ4//33GTduHFdffTV5eXl88MEH5brGtddey9/+9jc2bNjA2rVry3TO/fffz2WXXcayZcvYtm1bqeUmTZrEa6+9BpTsIgYnxkE8//zzvPzyy7Rp04aAgAD++OMPCgsLefTRR+nRowcRERGEhITQv39/vvjiC7fnSE9PZ9KkSURERNCoUSMmTpxIenq6x3j+/PNPRo8eTVRUFIGBgfTs2ZOVK1e6ldu1axdjxowhKiqK4OBg+vTpU6Irm7MLm2EYvPbaa67XNWPGDFq2bAnAPffcg8VioVWrVqf9W+bn5zNjxgzat29PYGAg8fHxjBw50lVX1q9fj8ViYf369SXO8zSOZNKkSYSGhrJz506GDBlCWFgY1157LVOnTiU0NJTc3Fy35x8/fjxxcXHY7XbXsU8++YT+/fsTEhJCWFgYQ4cO5ffffz/t6xARKY0SCxGRU9hsNkaOHIm/vz/jx49n+/btbNq0qUznZmRkcOzYMSIjI6s0ppUrV5Kdnc24ceOIi4tjwIAB5Up4nK677joA1qxZU65zDMM4bTJy8803c+mllwKwYMEC1+1kb7/9Nv/85z+56aabeOGFF4iKiiIzM5N58+YxYMAAnn32WWbMmEFqaiqXX345P/30k+tcwzC44oorWLBgARMmTODJJ59k//79TJw40S2W33//nT59+rB161buv/9+XnjhBUJCQrjyyit5//33XeVSUlLo168fn376KbfeeitPPfUU+fn5jBgxwlXuwgsvdL2OSy+91PW6Ro4cyUsvvQSYX9gXLFjgGtDtid1uZ9iwYTz++OP06NGDF154gdtvv52MjAx+++23078BpSguLubyyy8nNjaW559/nlGjRjF27FhycnLcxvnk5ua6urb5+PgA5vs0dOhQQkNDefbZZ3nkkUf4448/uOCCC9i9e3eFYhKRBs4QERGXzZs3G4Cxdu1awzAMw+FwGM2bNzduv/12t7KA8de//tVITU01Dh8+bGzevNkYNGiQARjPPfdcibJvv/22ARibNm2qUFzDhg0zzj//fNf+3LlzDV9fX+Pw4cMlyj322GMGYKSmpnq8zrFjxwzAuOqqq1zHJk6caISEhJT63D/++KMBGHfeeedpY5wyZYrh6b+VpKQkAzDCw8Pd4i0uLjYKCgrcYmzSpIlxww03uI795z//MQDj73//e4lz+/fvbwDG22+/7Tp+8cUXG507dzby8/NdxxwOh9GvXz+jXbt2rmN33HGHARhff/2161hWVpaRmJhotGrVyrDb7a7jgDFlyhSPr+vU99qTt956ywCMF1980e0xh8NhGIZhfPHFFwZgfPHFFx6f5+TXOHHiRAMw7r//frdrNWvWzBg1alSJ4++++64BGF999ZXrdTZq1Mi48cYbS5RLTk42IiIi3I6LiJSFWixERE5is9lo0qQJAwcOBMxuPWPHjmXJkiUlupA4/etf/yImJobY2Fh69uzJ559/zr333sv06dOrLKajR4/y6aefMn78eNexUaNGYbFYePfdd8t1rdDQUACysrKq9RxPRo0aRUxMTIljPj4+rnEWDoeDtLQ0iouL6dmzJz/88IOr3KpVq/D19eWWW24pce5tt91W4nppaWmsW7eOq6++mqysLI4cOcKRI0c4evQol19+Odu3b+fAgQOua/bq1YsLLrigxGu96aab2L17N3/88UelXu/Jli9fTnR0tFu8gKvLWEWc/PdwXmvMmDGsWrWK7Oxs1/GlS5fSrFkz12tdu3Yt6enpjB8/3vU3OnLkCD4+PvTu3dtjVzQRkTNRYiEicpzdbmfJkiUMHDiQpKQkduzYwY4dO+jduzcpKSl8/vnnbudcccUVrF27lo8//tg11Wtubi5Wa/k+XgsLC0lOTi5xcyYyS5cupaioiG7durliSktLo3fv3uXuDuX8shkWFlat53iSmJjo8fg777zDueeeS2BgII0bNyYmJoaPP/6YjIwMV5k9e/YQHx/vSnKczjrrrBL7O3bswDAMHnnkEWJiYkrcnAPwDx8+7LrmqeeDOU7G+XhV2blzJ2eddRa+vlU3Z4qvry/Nmzd3Oz527Fjy8vJcY0qys7NZtWoVY8aMcSUx27dvB+Avf/mL299pzZo1rr+RiEh5aFYoEZHjnNO5LlmyhCVLlrg9brPZuOyyy0oca968OZdccgkAQ4YMITo6mqlTpzJw4EBGjhxZ5uf+9ttvXa0kTklJSa6pZQHOP/98j+fu2rWL1q1bl+l5nP35S5s+t6rO8SQoKMjt2MKFC5k0aRJXXnkl99xzD7Gxsfj4+PD0009XaAC8c82Nu+++u9RZuSr7OqpLaS0XnlrKwJwi2FMC26dPH1q1asW7777LNddcw4cffkheXh5jx451lXH+nRYsWEBcXJzbNaoyARKRhkOfHCIix9lsNmJjY12zG51sxYoVvP/++7zxxhsevyA73Xzzzbz00ks8/PDDXHXVVWXu5tKlSxe3wdFxcXGuqW+nTp3KRRddVOJxh8PBddddx6JFi3j44YfL9DzOgcjlmQp3wYIFWCwW1+Ds0lSkS897771H69atWbFiRYnzT53et2XLlnz++edkZ2eXaLX43//+V6KcM8Hy8/NzJXyladmypdv5YM4o5Xy8qrRp04YNGzZQVFSEn5+fxzLOAf+nznRVkZaTq6++mldeeYXMzEyWLl1Kq1at6NOnT4l4AGJjY8/4dxIRKSt1hRIRwZzOdcWKFQwbNozRo0e73aZOnUpWVpbHKUtP5uvry1133cXWrVvLNR1sZGQkl1xySYlbYGCgq7Xi3nvvdYvp6quv5qKLLipzd6hFixYxb948+vbty8UXX1ymc5555hnWrFnD2LFjadeu3WnLOtdQKG0KWE+cMxQZhuE6tmHDBr777rsS5YYMGUJxcTGzZ892HbPb7fzzn/8sUS42NpYBAwYwZ84cDh065PZ8zrUnnNfcuHFjiefKyclh7ty5tGrVig4dOpT5dZzJqFGjOHLkCK+++qrbY87X3rJlS3x8fPjqq69KPP7666+X+/nGjh1LQUEB77zzDqtXr+bqq68u8fjll19OeHg4s2bNoqioyO38k/9OIiJlpRYLERHM6VyzsrIYMWKEx8f79OlDTEwMNputRJcSTyZNmsSjjz7Ks88+y5VXXlnisbfeeovVq1e7nXP77bd7HMNgs9no2rWr20rZTiNGjOC2227jhx9+oHv37q7j7733HqGhoRQWFrpW3v7mm2/o0qULy5Ytc7tOcXExCxcuBMz1Fvbs2cPKlSv55ZdfGDhwIHPnzj3tawbo0aMHANOmTePyyy/Hx8eHcePGnfacYcOGsWLFCq666iqGDh1KUlISb7zxBh06dCgx+Hj48OGcf/753H///ezevZsOHTqwYsWKEuMwnF577TUuuOACOnfuzI033kjr1q1JSUnhu+++Y//+/fz888+AuUbH4sWLGTx4MNOmTSMqKop33nmHpKQkli9fXu5xMqdz/fXX8+9//5vp06ezceNG+vfvT05ODp999hm3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888/z6ZNm4iMjGTTpk3MmjXrtOfcdNNNbmMAADp06FChmD355Zdf+PXXX3n66addx8aPH8+sWbP49NNP3VpUcnJyiImJKXHsggsu4J133sFisVRZXDabjZ49e7q66YeFhTF06FBsNht33HFHua4VenzcbVZWFuHh4WU+J6uGZxitk4mFv78/o0aNYsiQIURHR/PHH3/w/PPP079/f7799ttSZxooKCigoKDAte/M+ux2O3a7vUZiL5XdjsVwYNjt4O1Y6im73Y7D4fD+ey11huqMlJfqTP1ht9sxDMN1c6lM16XCQsjJMRMIi8W8z8kxj/v5mZcv7zUNo9wxOV/PG2+8wV133cWgQYP46quvPP5a7yxrGAZdu3bl7LPPxmaz0ahRI+Li4hg4cGCJMidvA7Rt25aLL774tHFU1oIFCwgJCSExMZHt27cD5sxPrVq1wmazuc1KFRgYyMqVKwHYv38/zz33HIcPHyYwMNBjTG514CSpqakl/r2HhoYSGhpKeno6q1atYsqUKa6YAPr168fy5cv53//+R/v27V3XP9PzZGdnu65/6t/5dOeEhYWd8e/svEZp34fL83lWJxOLfv360a9fP9f+iBEjGD16NOeeey4PPPCAa+7lUz399NM8/vjjbsd37tzpygS9xafoMJFH0zhm3YXdL9ursdRXDoeDtLQ0duzYgbUivwpJg6M6I+WlOlN/OBwOiouLS/wg6VLRfuuGgd///R/Wr76CuDhITsZx4YUUvfEGxXY7vr4V/FrmYf2F0ykqKgKgTZs2rFixgqFDh3LppZeybt06mjdvXqKssytRfn4++fn5jBkzhjfffJOwsDBGjRpFYWGhq6zdbnetBeH8uxUXF3tcH6KqOKdzzcnJoWPHjm6PHz58mCNHjri+59ntdnx8fLjgggtcZS666CK6devGjTfeyHvvved2jZNf16nOO++8EutMPPjggzz88MMsWrSIgoICXnzxRV588UW389555x0eeeQRoGx/q19//ZXY2Fj8/f3Jz893vYelnVNUVMS2bdvo0KHDGf/+BQUFFBcXs2fPHo+fW86kpizqZGLhSdu2bbniiitYsWKFq9Kc6oEHHmD69Omu/czMTBISEmjTpk2Zm5WqTV4oFkcUkYmtIajmpgVrSOx2Ozt27KBt27Ye64fIqVRnpLxUZ+qP/Px89uzZQ0BAAIGBgSUfrGDXIwDuvNOcDSotDQID8bnzTqyRkVBQQEBAQJV2xSmN3/HWkYCAAHr27Mn777/PsGHDGD58OF999VWJbkLOZCcwMJDAwECuv/56Zs6cSXJyMgsWLCjxt/Hx8XHtO8dd+Pr6uv/9qtD69es5cOAAjz/+OOecc06Jx44dO8bNN9/M6tWrXdO4Ov9dnhxTYmIid9xxB0888QQ//fST27IFJ7+uU9lsNvLy8lz7rVu3JjAwkGXLltGpUyceffRRt3Pmzp3LsmXLeOqpp4Az/62+++47du3axYQJE1yPO9/D0s55//33ycvLY9CgQWX6+/v6+tKyZUuPZcs6rgPqUWIBkJCQQGFhITk5OR4ThYCAAI8DjHx8fLz/H4CPD1is5r23Y6nHrFZr7Xi/pc5QnZHyUp2pH3x8fEqshlxl+vY1x2h89BEMG2buH1flz1UK53M4n++SSy5h8eLFjBkzhsGDB/PFF1+4vkedWrZt27a8/PLL5OXl0bt3b7frnly+Jl6TzWYjJCSEe++91+OX4ueff55FixZx3XXXucV6smnTpvH888/z7LPP8p///MetbGmv4eSWD6d9+/bx1Vdf8fjjj3scX1JUVMS1117Lxo0b6d2792n/Vnv27GHy5Mn4+/tzzz33lOnv+/PPP3PnnXcSGRnJ1KlTz/j3d16jtM+t8nyW1avEYteuXQQGBnq9W5OIiIiIRxYLTJtmjq2YNs3c9+KUs05XXXUVb775JjfccAMjRoxg9erVpf7Sffvtt5f5uj/88AMLFy50O96mTRv6npRUVYRzOtdLL7201FhHjBjBK6+8wuHDh4mNjS31Wo0bN2by5Mm8/vrrbN26tUTrx+bNmz0utjdgwACPicWiRYswDKPUmbaGDBmCr68vNputRHLm/Fs5HA7S09PZtGkTy5cvx2KxsGDBAs4991y3a3399dcUFBRgt9s5evQo33zzDStXriQiIoL333+fuLi4Ul9zdaiTiUVqaqrbaP6ff/6ZlStXMnjwYPVrFRERkdqrVy94/31vR+Fm8uTJpKWlcffddzNmzBjer4IYFy9eXGKKWqeJEydWOrH4+OOPSU9PZ/jw4aWWGT58OC+88AJLlixh2rRpp73e9OnTeeONN3j22WeZP3++6/iGDRvYsGGDW/mZM2d6TCxsNhstWrRwWyXbqVGjRlxwwQUsXbq0xPgL59/K19eX8PBw2rVrxx133MH//d//0aJFC4/X+uc//wmYXaMaNWrEOeecw+OPP86NN97o9l25JliMqhqSX4P+8pe/EBQURL9+/YiNjeWPP/5g7ty5+Pn58d1337n1sStNZmYmERERZGRk1IIxFodg+xxod7PGWFQTu93O9u3badeunbooSJmozkh5qc7UH/n5+SQlJZGYmFitYwTAHICcn59PYGBgjXSFkrqvKuvMmep6eb4v18kWiyuvvBKbzcaLL75IZmYmMTExjBw5kscee8w1V7CIiIiIiNScOplYTJs27YzNWSIiIiIiUnM0GEFERERERCqtTrZY1BtFWVB8fNGR/BRzPz/lxOO+oeAX5p3YRERERETKQYmFN6VtgZT15rajAAqPwp6lYD2+1kaTAeZNRERERKSWU2LhTVE9IPys0h/31XocIiIiIlI3KLHwJr8wdXUSERGpxergrPwi5VKVdVyDt0VERERO4efnB0Bubq6XIxGpXjk5OVgsFledrwy1WIiIiIicwsfHh0aNGnH48GEAgoODq23xOsMwKCgoANACeVImla0zhmFQXFxMZmYmmZmZNGrUqEoW9VRiISIiIuJBXFwcgCu5qC7OL3m+vr5KLKRMqqrO+Pj4EB8fT0RERJXEpcRCRERExAOLxUJ8fDyxsbEUFRVV2/PY7Xb27NlDy5Ytq+RXY6n/qqLO+Pr64uPjU6XJrBILERERkdPw8fGp1i/8drsdq9VKYGCgEgspk9paZzR4W0REREREKk2JhYiIiIiIVJoSCxERERERqTQlFiIiIiIiUmlKLEREREREpNIa9KxQziXMMzMzvRyJ1AS73U52djaZmZm1agYFqb1UZ6S8VGekIlRvpLxqss44vyc7vzefToNOLLKysgBISEjwciQiIiIiIrVXVlbWGRfSsxhlST/qKYfDwcGDBwkLC9NKlw1AZmYmCQkJ7Nu3j/DwcG+HI3WA6oyUl+qMVITqjZRXTdYZwzDIysqiadOmWK2nH0XRoFssrFYrzZs393YYUsPCw8P1wS3lojoj5aU6IxWheiPlVVN15kwtFU4avC0iIiIiIpWmxEJERERERCpNiYU0GAEBATz22GMEBAR4OxSpI1RnpLxUZ6QiVG+kvGprnWnQg7dFRERERKRqqMVCREREREQqTYmFiIiIiIhUmhILERERERGpNCUWUuds2rSJqVOn0rFjR0JCQmjRogVXX30127Ztcyu7detWBg0aRGhoKFFRUVx33XWkpqa6lXM4HPz9738nMTGRwMBAzj33XBYvXlwTL0e85KmnnsJisdCpUye3x7799lsuuOACgoODiYuLY9q0aWRnZ7uVKygo4L777qNp06YEBQXRu3dv1q5dWxPhSw364YcfGDFiBFFRUQQHB9OpUyf+8Y9/lCijOiNO27dvZ9y4cTRv3pzg4GDOPvtsnnjiCXJzc0uUU51pmLKzs3nssccYNGgQUVFRWCwW5s+f77FsdXyHKes1K8wQqWNGjRplxMXFGbfddpvx5ptvGjNnzjSaNGlihISEGL/++qur3L59+4zo6GijTZs2xiuvvGI89dRTRmRkpNGlSxejoKCgxDXvv/9+AzBuvPFGY+7cucbQoUMNwFi8eHFNvzypAfv27TOCg4ONkJAQo2PHjiUe+/HHH43AwECjW7duxuzZs42HHnrICAgIMAYNGuR2nXHjxhm+vr7G3XffbcyZM8fo27ev4evra3z99dc19VKkmn366aeGv7+/0bt3b+PFF1805s6da9x3333GPffc4yqjOiNOe/fuNRo1amS0bNnSePrpp405c+YYkyZNMgBjxIgRrnKqMw1XUlKSARgtWrQwBgwYYADG22+/7VauOr7DlOeaFaXEQuqcb775xu0fwLZt24yAgADj2muvdR275ZZbjKCgIGPPnj2uY2vXrjUAY86cOa5j+/fvN/z8/IwpU6a4jjkcDqN///5G8+bNjeLi4mp8NeINY8eONf7yl78YF110kVtiMXjwYCM+Pt7IyMhwHXvzzTcNwPj0009dxzZs2GAAxnPPPec6lpeXZ7Rp08bo27dv9b8IqXYZGRlGkyZNjKuuusqw2+2lllOdEaennnrKAIzffvutxPHrr7/eAIy0tDTDMFRnGrL8/Hzj0KFDhmEYxqZNm0pNLKrjO0xZr1kZSiyk3ujevbvRvXt3135sbKwxZswYt3Lt27c3Lr74Ytf+a6+9ZgDG77//XqLcokWLDEC/CtUzX375peHj42P88ssvbolFRkaG4evrW+LXaMMwjIKCAiM0NNT461//6jp2zz33GD4+PiW+GBiGYcyaNcsAjL1791bvC5FqN3v2bAMw/vjjD8MwDCM7O9stwVCdkZPdd999BmCkpqa6HbdarUZ2drbqjLicLrGoju8wZb1mZWiMhdQLhmGQkpJCdHQ0AAcOHODw4cP07NnTrWyvXr348ccfXfs//vgjISEhnHPOOW7lnI9L/WC327ntttv429/+RufOnd0e//XXXykuLnarN/7+/nTt2tWt3rRv357w8PASZZ315qeffqr6FyA16rPPPiM8PJwDBw5w1llnERoaSnh4OLfccgv5+fmA6oyUNGDAAAD++te/8tNPP7Fv3z6WLl3K7NmzmTZtGiEhIaozckbV8R2mPNesDCUWUi/YbDYOHDjA2LFjATh06BAA8fHxbmXj4+NJS0ujoKDAVbZJkyZYLBa3cgAHDx6sztClBr3xxhvs2bOHmTNnenz8TPXm5Lpw6NChUsuB6k19sH37doqLi7niiiu4/PLLWb58OTfccANvvPEGkydPBlRnpKRBgwYxc+ZM1q5dS7du3WjRogXjxo3jtttu46WXXgJUZ+TMquM7THmuWRm+lb6CiJf9+eefTJkyhb59+zJx4kQA8vLyADwudR8YGOgqExAQ4Lo/XTmp+44ePcqjjz7KI488QkxMjMcyZ6o3J9cF1Zv6Lzs7m9zcXP7v//7PNQvUyJEjKSwsZM6cOTzxxBOqM+KmVatWXHjhhYwaNYrGjRvz8ccfM2vWLOLi4pg6darqjJxRdXyHKc81K0OJhdRpycnJDB06lIiICN577z18fHwACAoKAvCYfTu7MDjLBAUFlamc1G0PP/wwUVFR3HbbbaWWOVO9ObkuqN7Uf873cPz48SWOX3PNNcyZM4fvvvuO4OBgQHVGTEuWLOGmm25i27ZtNG/eHDCTUYfDwX333cf48eP1OSNnVB3fYcpzzcpQVyipszIyMhg8eDDp6emsXr2apk2buh5zNvU5m/5OdujQIaKiolxZeXx8PMnJyRiG4VYOKHFdqZu2b9/O3LlzmTZtGgcPHmT37t3s3r2b/Px8ioqK2L17N2lpaWesN6fWsdLKgepNfeB8D5s0aVLieGxsLADHjh1TnZESXn/9dbp16+ZKKpxGjBhBbm4uP/74o+qMnFF1fIcpzzUrQ4mF1En5+fkMHz6cbdu28dFHH9GhQ4cSjzdr1oyYmBg2b97sdu7GjRvp2rWra79r167k5uaydevWEuU2bNjgelzqtgMHDuBwOJg2bRqJiYmu24YNG9i2bRuJiYk88cQTdOrUCV9fX7d6U1hYyE8//eRWb7Zt20ZmZmaJsqo39UePHj0As/6czNlnOSYmRnVGSkhJScFut7sdLyoqAqC4uFh1Rs6oOr7DlOealVIlc0uJ1KDi4mJjxIgRhq+vr/Hxxx+XWu7//u//jKCgoBLT8X322WcGYMyePdt1bN++faXOAd2sWTOtY1EPpKamGu+//77brWPHjkaLFi2M999/3/jll18MwzCMQYMGGfHx8UZmZqbr/Hnz5hmA8cknn7iOff/9927zy+fn5xtt27Y1evfuXXMvTqrNDz/8YADGNddcU+L4+PHjDV9fX+PAgQOGYajOyAnDhg0z/P39jf/9738ljl955ZWG1WpVnZESTjfdbHV8hynrNStDiYXUObfffrsBGMOHDzcWLFjgdnPau3ev0bhxY6NNmzbGP/7xD2PWrFlGZGSk0blzZyM/P7/ENe+55x4DMG666SbjzTffdK1aabPZavrlSQ3ytEDeli1bjICAgBIr4gYGBhqXXXaZ2/ljxoxxzUc/Z84co1+/foavr6/x5Zdf1tRLkGp2ww03GIBx9dVXG6+99poxZswYAzAeeOABVxnVGXFyrpMTGxtrPPHEE8Zrr71mDB482ACMv/3tb65yqjMN2z//+U9j5syZxi233GIAxsiRI42ZM2caM2fONNLT0w3DqJ7vMOW5ZkUpsZA656KLLjKAUm8n++2334zLLrvMCA4ONho1amRce+21RnJysts17Xa7MWvWLKNly5aGv7+/0bFjR2PhwoU19ZLESzwlFoZhGF9//bXRr18/IzAw0IiJiTGmTJlS4pdFp7y8POPuu+824uLijICAAOO8884zVq9eXROhSw0pLCw0ZsyYYbRs2dLw8/Mz2rZta7z00ktu5VRnxGnDhg3G4MGDjbi4OMPPz89o37698dRTTxlFRUUlyqnONFwtW7Ys9TtMUlKSq1x1fIcp6zUrymIYp4z2EBERERERKScN3hYRERERkUpTYiEiIiIiIpWmxEJERERERCpNiYWIiIiIiFSaEgsREREREak0JRYiIiIiIlJpSixERERERKTSlFiIiIiIiEilKbEQEREREZFKU2IhIiIiIiKVpsRCRESq1euvv47FYqF3794eH7dYLCVu4eHhXHTRRXz88cduZefPn4/FYmHz5s3VHbaIiJSTr7cDEBGR+s1ms9GqVSs2btzIjh07aNu2rVuZSy+9lOuvvx7DMNizZw+zZ89m+PDhfPLJJ1x++eVeiFpERMpLLRYiIlJtkpKS+Pbbb3nxxReJiYnBZrN5LNe+fXsmTJjAddddx8MPP8xnn32GYRi88sorNRyxiIhUlBILERGpNjabjcjISIYOHcro0aNLTSxOdc455xAdHc3OnTurOUIREakqSixERKTa2Gw2Ro4cib+/P+PHj2f79u1s2rTpjOdlZGRw7NgxIiMjayBKERGpCkosRESkWmzZsoU///yTcePGAXDBBRfQvHlzj60W+fn5HDlyhNTUVLZs2cK4ceOw2+2MHj26psMWEZEKUmIhIiLVwmaz0aRJEwYOHAiYsz+NHTuWJUuWYLfbS5T917/+RUxMDLGxsfTs2ZPPP/+ce++9l+nTp3sjdBERqQAlFiIiUuXsdjtLlixh4MCBJCUlsWPHDnbs2EHv3r1JSUnh888/L1H+iiuuYO3atXz88cfMmDEDi8VCbm4uVqv+mxIRqSs03ayIiFS5devWcejQIZYsWcKSJUvcHrfZbFx22WWu/ebNm3PJJZcAMGTIEKKjo5k6dSoDBw5k5MiRNRa3iIhUnBILERGpcjabjdjYWF577TW3x1asWMH777/PG2+8QVBQkMfzb775Zl566SUefvhhrrrqKiwWS3WHLCIilaTEQkREqlReXh4rVqxgzJgxHgdfN23alMWLF7Ny5UrGjh3r8Rq+vr7cdddd3HrrrXzwwQdceeWV1Ry1iIhUlhILERGpUitXriQrK4sRI0Z4fLxPnz6uxfJKSywAJk2axKOPPsqzzz7rlli89dZbrF692u2c22+/nbCwsErFLyIiFaPEQkREqpTNZiMwMJBLL73U4+NWq5WhQ4dis9k4evRoqdcJCgpi6tSpzJgxg/Xr1zNgwADXY7Nnz/Z4zqRJk5RYiIh4icUwDMPbQYiIiIiISN2mefxERERERKTSlFiIiIiIiEilKbEQEREREZFKU2IhIiIiIiKVpsRCREREREQqTYmFiIiIiIhUmhILERERERGpNCUWIiIiIiJSaUosRERERESk0pRYiIiIiIhIpSmxEBERERGRSlNiISIiIiIilabEQkREREREKu3/AfPUvwaouVy6AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure(figsize=(8, 4))\n",
    "plt.title(f\"ARL-ADD tradeoff curve\")\n",
    "\n",
    "# LB ARL-ADD line with error bars\n",
    "plt.plot(ls_LB_ARL, ls_LB_ADD,\n",
    "         marker=\"^\", markersize=4, linestyle=\"-\", color=\"orange\", label=\"LB      ARL-ADD\", alpha=0.8)\n",
    "plt.errorbar(ls_LB_ARL, ls_LB_ADD, \n",
    "             xerr=ls_LB_ARLerr, yerr=ls_LB_ADDerr, \n",
    "             fmt='none', capsize=3, capthick=1, elinewidth=1, color=\"orange\", alpha=0.5)\n",
    "\n",
    "# KME ARL-ADD line with error bars\n",
    "plt.plot(ls_KME_ARL, ls_KME_ADD,\n",
    "         marker=\"d\", markersize=4, linestyle=\"-\", color=\"red\", label=\"KME   ARL-ADD\", alpha=0.8)\n",
    "plt.errorbar(ls_KME_ARL, ls_KME_ADD, \n",
    "             xerr=ls_KME_ARLerr, yerr=ls_KME_ADDerr, \n",
    "             fmt='none', capsize=3, capthick=1, elinewidth=1, color=\"red\", alpha=0.5)\n",
    "\n",
    "# if duration < 500 and statistic_type == \"GSR\":\n",
    "#     plt.axvline(x=duration, color='green', linestyle='--', label=\"Max duration\", alpha=0.7)\n",
    "#     plt.axvspan(duration, 450, alpha=0.2, color='gray', label=\"Extrapolation region\") \n",
    "# elif duration < 300 and statistic_type == \"CUSUM\":\n",
    "#     plt.axvline(x=duration, color='green', linestyle='--', label=\"Max duration\", alpha=0.7)\n",
    "#     plt.axvspan(duration, 210, alpha=0.2, color='gray', label=\"Extrapolation region\")\n",
    "\n",
    "plt.grid(alpha=0.5)\n",
    "plt.xlabel(\"ARL\", fontsize=12)\n",
    "plt.ylabel(\"ADD\", fontsize=12)\n",
    "plt.tick_params(axis='both', which='both', labelsize=12)\n",
    "plt.legend(fontsize=12, loc='lower right')\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
