{"diffoscope-json-version": 1, "source1": "/srv/reproducible-results/rbuild-debian/r-b-build.DhDk3HqU/b1/pandas_2.2.3+dfsg-5_arm64.changes", "source2": "/srv/reproducible-results/rbuild-debian/r-b-build.DhDk3HqU/b2/pandas_2.2.3+dfsg-5_arm64.changes", "unified_diff": null, "details": [{"source1": "Files", "source2": "Files", "unified_diff": "@@ -1,5 +1,5 @@\n \n- 0b9cdcb6ce42ea66ad0a7ec10eb9317d 9245004 doc optional python-pandas-doc_2.2.3+dfsg-5_all.deb\n- 5aff3a31db594ff67f408f9a1af1115b 35728564 debug optional python3-pandas-lib-dbgsym_2.2.3+dfsg-5_arm64.deb\n- 43f0b2757428e0cd339c66c675a2aad3 3745844 python optional python3-pandas-lib_2.2.3+dfsg-5_arm64.deb\n+ 743d2359e95fc37ec9c7062aa88478f5 9245428 doc optional python-pandas-doc_2.2.3+dfsg-5_all.deb\n+ 28c6432bed825d012e6b189333c308fa 35729184 debug optional python3-pandas-lib-dbgsym_2.2.3+dfsg-5_arm64.deb\n+ 314c020a3db5276634ca16eaa07705fd 3745916 python optional python3-pandas-lib_2.2.3+dfsg-5_arm64.deb\n 82393119d6d8cb1b1ef15e3b71c2d0a7 3096356 python optional python3-pandas_2.2.3+dfsg-5_all.deb\n"}, {"source1": "python-pandas-doc_2.2.3+dfsg-5_all.deb", "source2": "python-pandas-doc_2.2.3+dfsg-5_all.deb", "unified_diff": null, "details": [{"source1": "file list", "source2": "file list", "unified_diff": "@@ -1,3 +1,3 @@\n -rw-r--r-- 0 0 0 4 2024-10-21 18:43:11.000000 debian-binary\n -rw-r--r-- 0 0 0 146904 2024-10-21 18:43:11.000000 control.tar.xz\n--rw-r--r-- 0 0 0 9097908 2024-10-21 18:43:11.000000 data.tar.xz\n+-rw-r--r-- 0 0 0 9098332 2024-10-21 18:43:11.000000 data.tar.xz\n"}, {"source1": "control.tar.xz", "source2": "control.tar.xz", "unified_diff": null, "details": [{"source1": "control.tar", "source2": "control.tar", "unified_diff": null, "details": [{"source1": "./md5sums", "source2": "./md5sums", "unified_diff": null, "details": [{"source1": "./md5sums", "source2": "./md5sums", "comments": ["Files differ"], "unified_diff": null}]}]}]}, {"source1": "data.tar.xz", "source2": "data.tar.xz", "unified_diff": null, "details": [{"source1": "data.tar", "source2": "data.tar", "unified_diff": null, "details": [{"source1": "file list", "source2": "file list", "unified_diff": "@@ -6230,61 +6230,61 @@\n -rw-r--r-- 0 root (0) root (0) 209237 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/reference/series.html\n -rw-r--r-- 0 root (0) root (0) 47718 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/reference/style.html\n -rw-r--r-- 0 root (0) root (0) 47710 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/reference/testing.html\n -rw-r--r-- 0 root (0) root (0) 52348 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/reference/window.html\n -rw-r--r-- 0 root (0) root (0) 244 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/release.html\n -rw-r--r-- 0 root (0) root (0) 269 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/reshaping.html\n -rw-r--r-- 0 root (0) root (0) 16236 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/search.html\n--rw-r--r-- 0 root (0) root (0) 2358554 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/searchindex.js\n+-rw-r--r-- 0 root (0) root (0) 2358571 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/searchindex.js\n -rw-r--r-- 0 root (0) root (0) 259 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/sparse.html\n -rw-r--r-- 0 root (0) root (0) 244 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/style.html\n -rw-r--r-- 0 root (0) root (0) 255 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/text.html\n -rw-r--r-- 0 root (0) root (0) 256 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/timedeltas.html\n -rw-r--r-- 0 root (0) root (0) 277 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/timeseries.html\n -rw-r--r-- 0 root (0) root (0) 272 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/tutorials.html\n drwxr-xr-x 0 root (0) root (0) 0 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/\n -rw-r--r-- 0 root (0) root (0) 170385 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/10min.html\n--rw-r--r-- 0 root (0) root (0) 282859 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/advanced.html\n+-rw-r--r-- 0 root (0) root (0) 282857 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/advanced.html\n -rw-r--r-- 0 root (0) root (0) 434987 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/basics.html\n -rw-r--r-- 0 root (0) root (0) 35684 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/boolean.html\n -rw-r--r-- 0 root (0) root (0) 216528 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/categorical.html\n -rw-r--r-- 0 root (0) root (0) 17366 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/cookbook.html\n -rw-r--r-- 0 root (0) root (0) 65178 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/copy_on_write.html\n -rw-r--r-- 0 root (0) root (0) 159345 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/dsintro.html\n -rw-r--r-- 0 root (0) root (0) 80419 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/duplicates.html\n--rw-r--r-- 0 root (0) root (0) 114409 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/enhancingperf.html\n+-rw-r--r-- 0 root (0) root (0) 114413 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/enhancingperf.html\n -rw-r--r-- 0 root (0) root (0) 106902 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/gotchas.html\n -rw-r--r-- 0 root (0) root (0) 299886 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/groupby.html\n -rw-r--r-- 0 root (0) root (0) 58768 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/index.html\n -rw-r--r-- 0 root (0) root (0) 394407 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/indexing.html\n -rw-r--r-- 0 root (0) root (0) 40816 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/integer_na.html\n -rw-r--r-- 0 root (0) root (0) 1144274 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/io.html\n -rw-r--r-- 0 root (0) root (0) 207911 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/merging.html\n -rw-r--r-- 0 root (0) root (0) 177680 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/missing_data.html\n -rw-r--r-- 0 root (0) root (0) 111206 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/options.html\n -rw-r--r-- 0 root (0) root (0) 146554 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/pyarrow.html\n -rw-r--r-- 0 root (0) root (0) 161699 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/reshaping.html\n--rw-r--r-- 0 root (0) root (0) 114620 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/scale.html\n+-rw-r--r-- 0 root (0) root (0) 114621 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/scale.html\n -rw-r--r-- 0 root (0) root (0) 64712 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/sparse.html\n -rw-r--r-- 0 root (0) root (0) 697282 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/style.html\n--rw-r--r-- 0 root (0) root (0) 87879 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/style.ipynb.gz\n+-rw-r--r-- 0 root (0) root (0) 87873 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/style.ipynb.gz\n -rw-r--r-- 0 root (0) root (0) 164343 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/text.html\n -rw-r--r-- 0 root (0) root (0) 99980 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/timedeltas.html\n -rw-r--r-- 0 root (0) root (0) 485612 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/timeseries.html\n -rw-r--r-- 0 root (0) root (0) 203394 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/visualization.html\n -rw-r--r-- 0 root (0) root (0) 141000 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/user_guide/window.html\n -rw-r--r-- 0 root (0) root (0) 270 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/visualization.html\n drwxr-xr-x 0 root (0) root (0) 0 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/\n -rw-r--r-- 0 root (0) root (0) 106734 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/index.html\n -rw-r--r-- 0 root (0) root (0) 10079 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/index.html.gz\n -rw-r--r-- 0 root (0) root (0) 83016 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.10.0.html\n -rw-r--r-- 0 root (0) root (0) 65522 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.10.1.html\n -rw-r--r-- 0 root (0) root (0) 81344 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.11.0.html\n -rw-r--r-- 0 root (0) root (0) 103349 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.12.0.html\n--rw-r--r-- 0 root (0) root (0) 221506 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.13.0.html\n+-rw-r--r-- 0 root (0) root (0) 221508 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.13.0.html\n -rw-r--r-- 0 root (0) root (0) 88415 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.13.1.html\n -rw-r--r-- 0 root (0) root (0) 242763 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.14.0.html\n -rw-r--r-- 0 root (0) root (0) 82295 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.14.1.html\n -rw-r--r-- 0 root (0) root (0) 251323 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.15.0.html\n -rw-r--r-- 0 root (0) root (0) 67310 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.15.1.html\n -rw-r--r-- 0 root (0) root (0) 74144 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.15.2.html\n -rw-r--r-- 0 root (0) root (0) 144231 2024-10-21 18:43:11.000000 ./usr/share/doc/python-pandas-doc/html/whatsnew/v0.16.0.html\n"}, {"source1": "./usr/share/doc/python-pandas-doc/html/searchindex.js", "source2": "./usr/share/doc/python-pandas-doc/html/searchindex.js", "unified_diff": null, "details": [{"source1": "js-beautify {}", "source2": "js-beautify {}", "unified_diff": "@@ -21494,31 +21494,31 @@\n \"001294\": 2210,\n \"001372\": 2207,\n \"001376\": 2207,\n \"001427\": 2214,\n \"001438\": 2195,\n \"001486\": [102, 1158],\n \"00180\": 2294,\n- \"002\": [2193, 2264],\n+ \"002\": 2264,\n \"002000\": 2232,\n \"002040\": 2235,\n \"002118\": [2230, 2231],\n \"002653\": 2207,\n \"002846\": 2229,\n- \"003\": [2185, 2193, 2235],\n+ \"003\": [2185, 2235],\n \"003144\": 2210,\n \"003337\": 2207,\n \"003494\": 15,\n \"003507\": [2209, 2218],\n \"003556\": 2207,\n \"00360\": 2294,\n \"003733\": 2207,\n \"003932\": 2216,\n \"003945\": 2210,\n- \"004\": [2186, 2193, 2227],\n+ \"004\": [2186, 2227],\n \"004000\": 2232,\n \"004005006\": [287, 939],\n \"004054\": 2229,\n \"004091\": [2204, 2257],\n \"004127\": 2207,\n \"004194\": 2186,\n \"004201\": 2186,\n@@ -21531,14 +21531,15 @@\n \"005000\": 2218,\n \"005361\": 2207,\n \"005383\": 2220,\n \"005446\": 2219,\n \"005462\": 2191,\n \"005977\": 2199,\n \"005979\": 2186,\n+ \"006\": 2193,\n \"006123\": 2207,\n \"006154\": [2185, 2197, 2199, 2202, 2204, 2215, 2257],\n \"0062\": 2191,\n \"006349\": 2195,\n \"006438\": 2215,\n \"006549\": [182, 760],\n \"006695\": 2186,\n@@ -21571,14 +21572,15 @@\n \"009783\": 2207,\n \"009797\": 2186,\n \"009826\": [102, 1158, 2205],\n \"009920\": [2184, 2195, 2214],\n \"00am\": 2230,\n \"00index\": 2218,\n \"01\": [3, 15, 16, 17, 19, 29, 30, 31, 79, 80, 82, 88, 107, 121, 182, 187, 207, 213, 218, 219, 230, 242, 261, 270, 271, 276, 277, 278, 283, 286, 287, 288, 289, 290, 291, 292, 293, 294, 295, 296, 298, 299, 301, 302, 303, 304, 305, 306, 307, 308, 309, 310, 311, 312, 313, 314, 315, 316, 317, 318, 319, 320, 321, 322, 323, 324, 326, 329, 330, 331, 332, 333, 345, 362, 363, 423, 445, 510, 511, 513, 514, 515, 516, 517, 519, 521, 523, 525, 529, 531, 532, 533, 534, 535, 536, 537, 541, 542, 543, 544, 545, 546, 547, 548, 549, 551, 554, 556, 557, 558, 560, 561, 562, 563, 564, 565, 566, 575, 591, 592, 593, 600, 629, 637, 639, 640, 641, 642, 643, 644, 645, 646, 647, 649, 650, 651, 652, 654, 655, 656, 657, 658, 659, 660, 661, 662, 663, 665, 666, 667, 668, 670, 671, 673, 674, 675, 676, 677, 678, 679, 680, 684, 685, 686, 688, 689, 696, 760, 763, 781, 788, 793, 804, 817, 874, 893, 898, 899, 902, 903, 904, 905, 909, 910, 917, 919, 922, 929, 934, 939, 940, 943, 944, 945, 948, 949, 953, 954, 957, 959, 960, 969, 972, 982, 984, 997, 1000, 1001, 1003, 1004, 1005, 1011, 1014, 1016, 1017, 1020, 1021, 1024, 1051, 1075, 1078, 1106, 1118, 1122, 1141, 1144, 1145, 1147, 1157, 1164, 1170, 1171, 1176, 1180, 1185, 1192, 1195, 1197, 1206, 1214, 1221, 1227, 1228, 1233, 1239, 1245, 1246, 1253, 1256, 1258, 1268, 1269, 1270, 1271, 1272, 1273, 1274, 1275, 1277, 1278, 1279, 1280, 1282, 1283, 1284, 1285, 1286, 1287, 1288, 1290, 1291, 1292, 1293, 1294, 1295, 1296, 1297, 1344, 1345, 1367, 1391, 1392, 1393, 1436, 1447, 1452, 1475, 1488, 1490, 1498, 1500, 1501, 1506, 1524, 1542, 1560, 1620, 1699, 1720, 1741, 1793, 1815, 1857, 1930, 1947, 1982, 2036, 2054, 2090, 2108, 2127, 2163, 2184, 2185, 2186, 2188, 2191, 2195, 2197, 2198, 2199, 2200, 2201, 2202, 2204, 2205, 2206, 2207, 2209, 2210, 2212, 2214, 2215, 2216, 2217, 2218, 2219, 2220, 2221, 2222, 2223, 2225, 2226, 2228, 2229, 2230, 2231, 2232, 2235, 2238, 2240, 2241, 2246, 2249, 2261, 2264, 2265, 2271, 2283, 2289, 2294, 2298, 2302, 2307],\n+ \"010\": 2193,\n \"0100\": [575, 893, 957, 970, 997, 1004, 1014, 1016, 1020, 1021, 1498, 2186, 2199, 2210, 2246, 2271],\n \"010000\": [954, 1894],\n \"010010012\": [923, 2209],\n \"010026\": 2191,\n \"010081\": 15,\n \"010165\": 2199,\n \"010589\": 2193,\n@@ -21597,14 +21599,15 @@\n \"011975\": 2207,\n \"012108\": 2207,\n \"012299\": 2207,\n \"0123456789123456\": [2164, 2165],\n \"012549\": 2207,\n \"012694\": 2199,\n \"012922\": 2219,\n+ \"013068\": 2228,\n \"013086\": 15,\n \"0133\": 2202,\n \"013448\": 2207,\n \"013605\": 2207,\n \"013684\": [182, 760],\n \"013692\": [102, 1158],\n \"013747\": 2199,\n@@ -21619,15 +21622,15 @@\n \"014138\": 2191,\n \"014144\": [102, 1158],\n \"014648\": 2186,\n \"014752\": 2235,\n \"014805\": 2202,\n \"014871\": [2185, 2197, 2199, 2202],\n \"014888\": 2207,\n- \"015\": 2193,\n+ \"014891\": 2228,\n \"015083\": 2186,\n \"015420\": 2195,\n \"015458\": 2207,\n \"015696\": [2220, 2228, 2230],\n \"015906\": 2186,\n \"015962\": [2184, 2214],\n \"015988\": 2186,\n@@ -21692,15 +21695,14 @@\n \"023526\": 2191,\n \"023640\": 2230,\n \"023688\": [15, 2185, 2191, 2197],\n \"0237\": 2204,\n \"023721\": 2207,\n \"023888\": 2186,\n \"023898\": 2195,\n- \"024\": 2193,\n \"024121\": 2207,\n \"024180\": [2185, 2197, 2199, 2202, 2204, 2215],\n \"024320\": 2210,\n \"02458\": 2195,\n \"024580\": [2184, 2195, 2214],\n \"024738\": [102, 1158],\n \"024786\": 2207,\n@@ -21774,15 +21776,15 @@\n \"033350\": 2207,\n \"033387\": 2186,\n \"033606\": 2186,\n \"033606102414146\": 2186,\n \"033695\": 2186,\n \"033718\": 2204,\n \"033823\": 2210,\n- \"034\": 1433,\n+ \"034\": [1433, 2193],\n \"034069\": 2195,\n \"034326\": [2184, 2257],\n \"034374\": 2210,\n \"034446\": 2207,\n \"034512\": 2207,\n \"034523\": 2210,\n \"034571\": 2197,\n@@ -21921,14 +21923,15 @@\n \"052849\": 2212,\n \"0530\": [1498, 2246],\n \"053136\": 2191,\n \"053365\": [182, 760],\n \"053667\": 2207,\n \"053768\": 2199,\n \"053785\": 2219,\n+ \"054\": 2193,\n \"054325\": 2191,\n \"0549\": 2202,\n \"054932\": 2207,\n \"054972\": 2207,\n \"055224\": 2184,\n \"055300\": 2212,\n \"055457\": 2199,\n@@ -21964,29 +21967,28 @@\n \"059481\": 2207,\n \"059552\": 2207,\n \"059761\": 2207,\n \"059869e\": 2191,\n \"059881\": 2210,\n \"059904\": 2214,\n \"05t00\": 2261,\n- \"06\": [26, 27, 29, 30, 31, 207, 213, 218, 230, 273, 292, 294, 332, 363, 526, 534, 536, 637, 644, 646, 688, 781, 788, 793, 804, 900, 969, 993, 1075, 1344, 1441, 1442, 1449, 1450, 1452, 1489, 1497, 1500, 1506, 1524, 1598, 1677, 2184, 2186, 2195, 2197, 2199, 2201, 2204, 2205, 2207, 2209, 2210, 2212, 2214, 2215, 2216, 2217, 2218, 2219, 2222, 2226, 2228, 2230, 2231, 2232, 2235, 2246, 2249, 2261, 2264, 2271, 2298, 2302],\n+ \"06\": [26, 27, 29, 30, 31, 207, 213, 218, 230, 273, 292, 294, 332, 363, 526, 534, 536, 637, 644, 646, 688, 781, 788, 793, 804, 900, 969, 993, 1075, 1344, 1441, 1442, 1449, 1450, 1452, 1489, 1497, 1500, 1506, 1524, 1598, 1677, 2184, 2186, 2195, 2197, 2199, 2201, 2204, 2205, 2207, 2209, 2210, 2212, 2214, 2215, 2216, 2217, 2218, 2219, 2222, 2226, 2230, 2231, 2232, 2235, 2246, 2249, 2261, 2264, 2271, 2298, 2302],\n \"060015\": 2207,\n \"060074\": 2185,\n \"060603\": 2207,\n \"060654\": 2207,\n \"060777\": 2207,\n \"061019\": 2199,\n \"061068\": 2210,\n \"061233\": 2207,\n \"061438\": 2199,\n \"061645\": 2193,\n \"061810\": 2204,\n \"061876\": [182, 760],\n \"061932\": 2186,\n- \"062\": 2193,\n \"062191\": 2230,\n \"062320\": 2207,\n \"062433\": 2199,\n \"062993\": 2197,\n \"0630\": 2246,\n \"063038\": 2199,\n \"063123\": 2210,\n@@ -22252,20 +22254,20 @@\n \"0n\": [1489, 2298],\n \"0px\": 2207,\n \"0rc0\": 13,\n \"0th\": [26, 249, 882, 1202, 2185, 2197, 2199, 2235],\n \"0x00\": 2294,\n \"0x40\": 2294,\n \"0x7efd0c0b0690\": 3,\n- \"0xffff11a60e90\": 2230,\n- \"0xffff4fb85570\": 2197,\n- \"0xffff508b4bf0\": 2199,\n- \"0xffff536b76e0\": 2195,\n- \"0xffff69d61d60\": 2246,\n- \"0xffff721d80e0\": 2210,\n+ \"0xffff492d2540\": 2230,\n+ \"0xffff86359d60\": 2199,\n+ \"0xffff86959570\": 2197,\n+ \"0xffff8a4cb7d0\": 2195,\n+ \"0xffffa17c9280\": 2246,\n+ \"0xffffa8f39300\": 2210,\n \"1\": [1, 2, 4, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 34, 35, 39, 42, 44, 46, 49, 54, 56, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 82, 83, 84, 85, 86, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 118, 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 134, 135, 136, 137, 138, 139, 140, 141, 143, 144, 145, 146, 148, 149, 151, 153, 154, 155, 156, 157, 158, 159, 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, 177, 178, 180, 182, 183, 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220, 221, 222, 223, 224, 225, 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, 240, 241, 242, 243, 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, 255, 256, 257, 258, 260, 261, 262, 263, 264, 265, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 280, 281, 282, 283, 284, 285, 286, 287, 288, 289, 290, 291, 292, 293, 294, 295, 296, 298, 299, 300, 301, 303, 304, 305, 306, 307, 308, 309, 310, 311, 312, 313, 314, 315, 317, 318, 319, 321, 323, 324, 325, 326, 327, 328, 329, 331, 332, 333, 337, 339, 341, 345, 346, 347, 348, 349, 350, 351, 352, 353, 354, 355, 356, 357, 358, 361, 363, 364, 366, 367, 370, 371, 372, 375, 376, 377, 378, 380, 382, 384, 385, 386, 387, 388, 389, 390, 392, 393, 394, 395, 396, 397, 398, 399, 400, 401, 403, 404, 405, 406, 407, 408, 409, 411, 412, 414, 415, 416, 417, 419, 420, 421, 422, 423, 424, 425, 426, 427, 429, 430, 431, 432, 433, 434, 435, 436, 437, 440, 446, 449, 450, 451, 455, 456, 459, 460, 461, 462, 463, 464, 465, 466, 467, 468, 469, 473, 475, 476, 477, 478, 481, 482, 483, 484, 485, 486, 487, 488, 489, 490, 491, 492, 493, 495, 496, 498, 499, 500, 501, 502, 503, 505, 509, 510, 511, 514, 516, 519, 525, 531, 532, 533, 534, 536, 540, 543, 545, 547, 548, 549, 551, 557, 558, 561, 565, 568, 569, 571, 573, 574, 575, 576, 577, 578, 579, 580, 581, 582, 583, 584, 585, 586, 589, 590, 591, 592, 593, 594, 595, 596, 597, 599, 600, 601, 602, 603, 604, 609, 613, 614, 615, 616, 618, 619, 620, 621, 622, 623, 624, 625, 626, 627, 628, 629, 630, 631, 632, 633, 634, 635, 636, 637, 639, 640, 641, 642, 643, 644, 645, 646, 647, 648, 649, 650, 651, 652, 654, 655, 656, 657, 658, 659, 660, 661, 662, 663, 664, 665, 666, 667, 668, 669, 671, 673, 674, 675, 676, 678, 679, 680, 681, 682, 683, 684, 686, 688, 689, 690, 691, 692, 694, 695, 696, 697, 698, 699, 700, 701, 702, 703, 704, 705, 706, 707, 709, 710, 711, 712, 713, 714, 715, 716, 717, 719, 720, 721, 722, 723, 724, 725, 726, 727, 728, 729, 730, 731, 732, 733, 734, 735, 736, 737, 738, 739, 740, 741, 743, 744, 747, 748, 749, 750, 751, 752, 753, 755, 756, 758, 760, 761, 762, 763, 764, 765, 766, 767, 768, 769, 770, 771, 772, 773, 774, 775, 776, 777, 778, 779, 780, 781, 782, 783, 784, 785, 786, 787, 788, 789, 790, 791, 792, 793, 794, 795, 796, 797, 798, 799, 800, 801, 802, 803, 804, 805, 806, 807, 808, 810, 812, 813, 814, 815, 816, 817, 819, 820, 821, 822, 823, 824, 825, 826, 827, 828, 829, 830, 831, 832, 833, 834, 835, 836, 837, 838, 839, 840, 841, 842, 843, 844, 845, 846, 847, 848, 849, 850, 852, 853, 854, 855, 856, 857, 858, 859, 860, 861, 862, 863, 864, 865, 866, 867, 868, 869, 870, 871, 872, 873, 874, 875, 876, 877, 878, 879, 880, 881, 882, 883, 884, 885, 886, 887, 888, 889, 891, 892, 894, 895, 896, 897, 898, 899, 900, 901, 902, 903, 904, 905, 906, 907, 908, 909, 910, 912, 913, 914, 916, 918, 921, 923, 927, 930, 938, 939, 940, 941, 942, 943, 945, 946, 947, 948, 949, 950, 951, 952, 953, 957, 959, 960, 970, 977, 979, 981, 984, 994, 997, 1003, 1004, 1005, 1006, 1011, 1012, 1021, 1031, 1032, 1033, 1034, 1035, 1036, 1038, 1039, 1040, 1041, 1042, 1043, 1044, 1045, 1046, 1047, 1048, 1049, 1050, 1051, 1052, 1053, 1054, 1055, 1056, 1057, 1058, 1059, 1060, 1061, 1062, 1063, 1064, 1065, 1066, 1067, 1068, 1069, 1071, 1072, 1073, 1074, 1075, 1076, 1077, 1078, 1079, 1080, 1081, 1082, 1083, 1084, 1085, 1086, 1087, 1088, 1089, 1091, 1092, 1093, 1095, 1096, 1097, 1099, 1100, 1101, 1102, 1103, 1104, 1105, 1106, 1108, 1109, 1110, 1111, 1112, 1113, 1114, 1115, 1118, 1119, 1121, 1123, 1124, 1125, 1126, 1127, 1128, 1129, 1130, 1131, 1132, 1133, 1134, 1135, 1136, 1137, 1138, 1139, 1140, 1141, 1142, 1143, 1145, 1146, 1147, 1148, 1149, 1150, 1151, 1152, 1153, 1155, 1156, 1157, 1158, 1159, 1160, 1161, 1162, 1163, 1164, 1165, 1166, 1167, 1168, 1169, 1170, 1171, 1172, 1173, 1174, 1175, 1176, 1177, 1178, 1179, 1180, 1181, 1182, 1183, 1184, 1185, 1186, 1187, 1188, 1189, 1190, 1191, 1192, 1193, 1194, 1195, 1196, 1197, 1198, 1199, 1200, 1201, 1202, 1203, 1204, 1205, 1206, 1207, 1208, 1209, 1210, 1211, 1212, 1213, 1214, 1215, 1216, 1217, 1218, 1219, 1220, 1221, 1222, 1223, 1224, 1225, 1226, 1227, 1228, 1229, 1230, 1231, 1232, 1233, 1234, 1235, 1236, 1237, 1238, 1239, 1240, 1241, 1244, 1245, 1246, 1247, 1248, 1249, 1250, 1251, 1252, 1253, 1254, 1255, 1256, 1257, 1258, 1259, 1260, 1261, 1262, 1263, 1264, 1265, 1267, 1268, 1269, 1270, 1271, 1272, 1273, 1274, 1275, 1276, 1277, 1278, 1279, 1280, 1281, 1282, 1283, 1284, 1285, 1286, 1287, 1288, 1289, 1290, 1291, 1292, 1293, 1294, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302, 1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312, 1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322, 1323, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1332, 1333, 1334, 1335, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1347, 1348, 1350, 1354, 1355, 1358, 1359, 1362, 1363, 1368, 1369, 1372, 1373, 1374, 1375, 1377, 1380, 1381, 1382, 1383, 1384, 1385, 1387, 1388, 1389, 1390, 1391, 1393, 1394, 1395, 1396, 1397, 1398, 1399, 1400, 1402, 1403, 1404, 1405, 1406, 1407, 1408, 1409, 1410, 1411, 1413, 1414, 1415, 1416, 1417, 1419, 1421, 1422, 1423, 1424, 1430, 1431, 1432, 1433, 1434, 1435, 1436, 1437, 1438, 1439, 1440, 1441, 1442, 1443, 1444, 1445, 1446, 1447, 1448, 1449, 1450, 1453, 1454, 1455, 1457, 1458, 1459, 1460, 1462, 1463, 1464, 1466, 1467, 1468, 1469, 1470, 1473, 1474, 1475, 1476, 1477, 1478, 1479, 1480, 1482, 1483, 1485, 1486, 1487, 1488, 1489, 1490, 1491, 1493, 1494, 1495, 1496, 1497, 1498, 1499, 1500, 1502, 1506, 1507, 1509, 1510, 1511, 1512, 1513, 1514, 1515, 1516, 1517, 1524, 1525, 1527, 1528, 1529, 1530, 1531, 1532, 1533, 1534, 1535, 1542, 1543, 1545, 1546, 1547, 1548, 1549, 1550, 1551, 1552, 1553, 1560, 1561, 1563, 1564, 1565, 1566, 1567, 1568, 1569, 1570, 1571, 1578, 1580, 1583, 1584, 1585, 1586, 1587, 1588, 1589, 1590, 1591, 1598, 1600, 1604, 1605, 1606, 1607, 1608, 1609, 1610, 1611, 1612, 1620, 1621, 1623, 1624, 1625, 1626, 1627, 1628, 1629, 1630, 1631, 1637, 1638, 1640, 1641, 1642, 1643, 1644, 1645, 1646, 1647, 1648, 1657, 1659, 1662, 1663, 1664, 1665, 1666, 1667, 1668, 1669, 1670, 1677, 1679, 1683, 1684, 1685, 1686, 1687, 1688, 1689, 1690, 1691, 1699, 1701, 1704, 1705, 1706, 1707, 1708, 1709, 1710, 1711, 1712, 1720, 1722, 1725, 1726, 1727, 1728, 1729, 1730, 1731, 1732, 1733, 1741, 1742, 1744, 1745, 1746, 1747, 1748, 1749, 1750, 1751, 1752, 1758, 1759, 1763, 1764, 1765, 1766, 1767, 1768, 1769, 1770, 1776, 1777, 1779, 1780, 1781, 1782, 1783, 1784, 1785, 1786, 1787, 1793, 1794, 1798, 1799, 1800, 1801, 1802, 1803, 1804, 1805, 1806, 1815, 1816, 1820, 1821, 1822, 1823, 1824, 1825, 1826, 1827, 1828, 1839, 1840, 1844, 1845, 1846, 1847, 1848, 1849, 1850, 1851, 1857, 1858, 1860, 1861, 1862, 1863, 1864, 1865, 1866, 1867, 1868, 1876, 1877, 1881, 1882, 1883, 1884, 1885, 1886, 1887, 1888, 1894, 1895, 1899, 1900, 1901, 1902, 1903, 1904, 1905, 1906, 1912, 1913, 1917, 1918, 1919, 1920, 1921, 1922, 1923, 1924, 1930, 1931, 1933, 1934, 1935, 1936, 1937, 1938, 1939, 1940, 1941, 1947, 1948, 1950, 1951, 1952, 1953, 1954, 1955, 1956, 1957, 1958, 1964, 1965, 1969, 1970, 1971, 1972, 1973, 1974, 1975, 1976, 1982, 1983, 1985, 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 2000, 2001, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2018, 2019, 2023, 2024, 2025, 2026, 2027, 2028, 2029, 2030, 2036, 2037, 2040, 2041, 2042, 2043, 2044, 2045, 2046, 2047, 2048, 2054, 2055, 2058, 2059, 2060, 2061, 2062, 2063, 2064, 2065, 2066, 2073, 2077, 2078, 2079, 2080, 2081, 2082, 2083, 2084, 2090, 2091, 2093, 2094, 2095, 2096, 2097, 2098, 2099, 2100, 2101, 2108, 2109, 2111, 2112, 2113, 2114, 2115, 2116, 2117, 2118, 2119, 2127, 2128, 2130, 2131, 2132, 2133, 2134, 2135, 2136, 2137, 2138, 2145, 2146, 2148, 2149, 2150, 2151, 2152, 2153, 2154, 2155, 2156, 2163, 2164, 2165, 2166, 2184, 2185, 2186, 2187, 2188, 2190, 2191, 2192, 2193, 2194, 2195, 2196, 2197, 2198, 2199, 2200, 2201, 2202, 2203, 2204, 2205, 2206, 2208, 2209, 2210, 2211, 2212, 2214, 2216, 2217, 2218, 2220, 2222, 2224, 2225, 2227, 2228, 2230, 2232, 2238, 2240, 2241, 2243, 2245, 2246, 2249, 2257, 2259, 2260, 2263, 2298, 2307, 2309, 2310],\n \"10\": [2, 3, 5, 6, 9, 10, 15, 16, 17, 18, 19, 21, 22, 24, 25, 26, 27, 28, 29, 30, 31, 32, 68, 69, 74, 80, 83, 84, 85, 88, 91, 94, 97, 98, 102, 105, 109, 111, 113, 119, 120, 121, 129, 133, 137, 138, 139, 140, 142, 144, 160, 163, 171, 173, 187, 188, 189, 190, 192, 193, 199, 202, 203, 204, 206, 207, 212, 213, 215, 216, 217, 220, 221, 222, 223, 228, 230, 234, 244, 258, 265, 268, 275, 276, 278, 284, 286, 288, 289, 293, 295, 296, 298, 300, 302, 316, 317, 318, 322, 323, 324, 329, 330, 331, 345, 395, 423, 427, 440, 445, 509, 514, 516, 534, 536, 544, 546, 551, 554, 556, 560, 562, 568, 569, 570, 571, 572, 577, 583, 592, 594, 595, 596, 600, 620, 621, 627, 635, 639, 641, 645, 647, 648, 649, 650, 652, 670, 671, 673, 677, 678, 679, 681, 684, 685, 686, 695, 696, 708, 713, 714, 738, 741, 763, 764, 765, 766, 768, 781, 787, 788, 798, 804, 808, 836, 837, 838, 839, 840, 841, 842, 843, 844, 849, 852, 863, 868, 874, 889, 895, 902, 904, 912, 923, 940, 942, 943, 944, 948, 957, 959, 960, 970, 982, 984, 995, 997, 1001, 1003, 1004, 1005, 1011, 1016, 1020, 1021, 1069, 1071, 1072, 1075, 1109, 1154, 1158, 1162, 1163, 1173, 1174, 1175, 1180, 1185, 1189, 1195, 1200, 1205, 1219, 1220, 1230, 1239, 1246, 1250, 1256, 1261, 1264, 1267, 1284, 1288, 1291, 1292, 1294, 1297, 1298, 1299, 1306, 1308, 1319, 1324, 1343, 1344, 1345, 1350, 1367, 1387, 1391, 1403, 1411, 1416, 1418, 1420, 1421, 1440, 1447, 1451, 1452, 1458, 1462, 1467, 1473, 1478, 1479, 1482, 1485, 1488, 1490, 1491, 1498, 1598, 1657, 1677, 1699, 1720, 1741, 1758, 1894, 1912, 2018, 2185, 2186, 2188, 2190, 2191, 2192, 2193, 2194, 2195, 2196, 2197, 2198, 2199, 2200, 2201, 2202, 2203, 2204, 2205, 2206, 2207, 2208, 2209, 2210, 2211, 2212, 2216, 2217, 2218, 2219, 2220, 2221, 2222, 2223, 2224, 2225, 2226, 2227, 2228, 2229, 2230, 2231, 2232, 2234, 2235, 2238, 2240, 2241, 2246, 2249, 2254, 2257, 2260, 2261, 2264, 2265, 2271, 2277, 2283, 2289, 2290, 2294, 2298, 2302, 2307, 2308],\n \"100\": [3, 15, 17, 22, 30, 68, 97, 98, 111, 118, 132, 135, 141, 142, 145, 159, 161, 175, 182, 192, 202, 207, 212, 213, 233, 273, 303, 345, 359, 360, 427, 577, 587, 588, 620, 621, 655, 709, 717, 760, 781, 787, 788, 900, 1345, 1391, 1398, 1447, 1457, 1472, 1473, 1488, 1490, 2184, 2185, 2186, 2188, 2190, 2191, 2193, 2194, 2195, 2197, 2199, 2200, 2201, 2202, 2204, 2207, 2208, 2209, 2210, 2211, 2212, 2218, 2220, 2222, 2223, 2225, 2226, 2230, 2231, 2232, 2235, 2241, 2242, 2246, 2249, 2302, 2307],\n \"1000\": [9, 10, 15, 16, 17, 18, 19, 24, 25, 28, 29, 32, 102, 141, 183, 191, 193, 194, 427, 717, 761, 767, 768, 769, 874, 1154, 1158, 1456, 1465, 1467, 1876, 1964, 2184, 2185, 2186, 2188, 2193, 2195, 2199, 2205, 2206, 2207, 2210, 2211, 2220, 2223, 2229, 2230, 2235, 2238, 2246, 2249, 2261, 2294],\n \"10000\": [192, 1485, 2185, 2201, 2206, 2210, 2220, 2228, 2266],\n \"100000\": [1354, 1372, 2199, 2201, 2210],\n \"1000000\": [144, 2199, 2228],\n@@ -22428,15 +22430,15 @@\n \"10387\": 2228,\n \"10388\": 2228,\n \"1039\": 2202,\n \"10390\": 2246,\n \"10392\": 2228,\n \"10393\": 2228,\n \"10395\": 2228,\n- \"104\": [2184, 2185, 2186, 2188, 2191, 2195, 2197, 2199, 2200, 2201, 2204, 2208, 2209, 2210, 2211, 2218, 2220, 2222, 2226, 2230, 2232, 2235, 2246, 2253, 2294],\n+ \"104\": [2184, 2185, 2186, 2188, 2191, 2193, 2195, 2197, 2199, 2200, 2201, 2204, 2208, 2209, 2210, 2211, 2218, 2220, 2222, 2226, 2230, 2232, 2235, 2246, 2253, 2294],\n \"1040\": 2202,\n \"104011\": 2235,\n \"10408\": 2228,\n \"10409\": 2235,\n \"1041\": 2205,\n \"10411\": 2228,\n \"10412\": 2228,\n@@ -22634,15 +22636,15 @@\n \"109291\": 2210,\n \"1093\": [16, 17, 18, 19, 2199, 2210, 2235],\n \"10932\": 2246,\n \"10939\": 2228,\n \"1094\": [16, 17, 18, 19, 2199, 2210, 2235],\n \"10940\": 2257,\n \"10946\": 2228,\n- \"1095\": [16, 17, 18, 19, 2193, 2199, 2210, 2235],\n+ \"1095\": [16, 17, 18, 19, 2199, 2210, 2235],\n \"109503\": 2207,\n \"10952\": 2228,\n \"109597\": 2186,\n \"1096\": 2210,\n \"10962\": 2228,\n \"10967\": 2238,\n \"1097\": 2210,\n@@ -22664,15 +22666,15 @@\n \"10h\": [2210, 2235],\n \"10m\": [16, 1447, 2200],\n \"10min\": 2230,\n \"10t00\": 2261,\n \"10th\": [2205, 2241],\n \"10x\": [1469, 1486, 1498, 2216, 2219, 2225, 2257],\n \"11\": [2, 10, 15, 17, 18, 19, 22, 24, 25, 26, 27, 28, 29, 30, 31, 32, 88, 108, 111, 113, 120, 127, 139, 140, 157, 162, 196, 213, 286, 288, 289, 293, 295, 296, 300, 316, 317, 318, 323, 324, 329, 330, 420, 423, 440, 509, 512, 518, 522, 524, 526, 530, 534, 536, 554, 556, 600, 635, 639, 641, 645, 647, 649, 650, 652, 670, 671, 673, 678, 679, 681, 684, 685, 703, 732, 771, 788, 799, 940, 943, 948, 985, 993, 1010, 1019, 1023, 1025, 1169, 1174, 1175, 1195, 1200, 1226, 1256, 1261, 1276, 1292, 1298, 1299, 1306, 1308, 1321, 1433, 1452, 1482, 1498, 1542, 1560, 1598, 1620, 1637, 1677, 1699, 1720, 1741, 1839, 1930, 2184, 2185, 2186, 2188, 2190, 2191, 2192, 2193, 2194, 2195, 2197, 2198, 2199, 2200, 2201, 2202, 2203, 2204, 2205, 2206, 2207, 2208, 2209, 2210, 2211, 2212, 2214, 2215, 2217, 2218, 2219, 2220, 2222, 2223, 2224, 2225, 2228, 2229, 2230, 2231, 2232, 2235, 2238, 2240, 2241, 2246, 2249, 2250, 2257, 2261, 2264, 2265, 2271, 2277, 2278, 2283, 2289, 2294, 2297, 2298, 2302, 2307],\n- \"110\": [213, 359, 360, 587, 588, 788, 2184, 2185, 2186, 2188, 2191, 2195, 2197, 2199, 2200, 2201, 2204, 2207, 2208, 2209, 2210, 2211, 2218, 2220, 2222, 2223, 2230, 2232, 2235, 2246],\n+ \"110\": [213, 359, 360, 587, 588, 788, 2184, 2185, 2186, 2188, 2191, 2193, 2195, 2197, 2199, 2200, 2201, 2204, 2207, 2208, 2209, 2210, 2211, 2218, 2220, 2222, 2223, 2230, 2232, 2235, 2246],\n \"1100\": [2195, 2210],\n \"11000\": [2185, 2220],\n \"11002\": 2228,\n \"11007\": 2229,\n \"1101\": 2210,\n \"11010\": 2228,\n \"11014\": 2228,\n@@ -22780,15 +22782,15 @@\n \"11283\": 2229,\n \"11285\": 2229,\n \"11287\": 2232,\n \"112932\": 15,\n \"11295\": 2229,\n \"11296\": 2241,\n \"11299\": 2231,\n- \"113\": [2184, 2185, 2186, 2188, 2191, 2195, 2197, 2199, 2200, 2201, 2204, 2208, 2209, 2210, 2211, 2230, 2232, 2246],\n+ \"113\": [2184, 2185, 2186, 2188, 2191, 2193, 2195, 2197, 2199, 2200, 2201, 2204, 2208, 2209, 2210, 2211, 2230, 2232, 2246],\n \"11300\": [176, 179, 754, 757, 1242, 1243],\n \"11302\": 2229,\n \"11305\": 2229,\n \"113063\": 2207,\n \"11308\": [2229, 2235],\n \"11310\": 2238,\n \"11312\": 2298,\n@@ -23136,15 +23138,15 @@\n \"12182\": 2230,\n \"12185\": 2232,\n \"12190\": 2238,\n \"121950\": 2207,\n \"12198\": 2230,\n \"121991\": 2207,\n \"122\": [2184, 2185, 2186, 2188, 2191, 2195, 2197, 2199, 2200, 2201, 2204, 2207, 2208, 2209, 2210, 2211, 2220, 2232],\n- \"1220\": [2193, 2298],\n+ \"1220\": 2298,\n \"12202\": 2230,\n \"12203\": 2231,\n \"1221\": 2298,\n \"12211\": 2231,\n \"12213\": 2265,\n \"12216\": 2232,\n \"12217\": 2230,\n@@ -23202,15 +23204,15 @@\n \"12386\": 2230,\n \"12388\": 2232,\n \"1239\": [2185, 2191, 2194],\n \"12392\": 2238,\n \"12396\": 2241,\n \"12397\": 2235,\n \"12399\": 2232,\n- \"124\": [2184, 2185, 2186, 2188, 2191, 2195, 2197, 2199, 2200, 2201, 2204, 2208, 2210, 2211, 2220, 2232],\n+ \"124\": [2184, 2185, 2186, 2188, 2191, 2193, 2195, 2197, 2199, 2200, 2201, 2204, 2208, 2210, 2211, 2220, 2232],\n \"1240\": [2185, 2191, 2194],\n \"12401\": 2238,\n \"12405\": 2236,\n \"12409\": 2230,\n \"12411\": 2231,\n \"124124\": 2207,\n \"12424\": 2232,\n@@ -24102,15 +24104,15 @@\n \"14882\": 2235,\n \"14883\": 2235,\n \"14885\": 2249,\n \"14887\": 2235,\n \"1489\": 2197,\n \"14894\": 2234,\n \"14898\": 2235,\n- \"149\": [2184, 2185, 2186, 2188, 2193, 2195, 2197, 2199, 2200, 2201, 2202, 2210, 2211, 2232],\n+ \"149\": [2184, 2185, 2186, 2188, 2195, 2197, 2199, 2200, 2201, 2202, 2210, 2211, 2232],\n \"1490\": 2197,\n \"14901\": 2235,\n \"1490195805\": [1498, 2210],\n \"1490195805433502912\": [1498, 2210],\n \"14908\": 2235,\n \"1491\": 2197,\n \"14910\": 2235,\n@@ -24573,15 +24575,15 @@\n \"16357\": 2241,\n \"16359\": 2238,\n \"16361\": 2236,\n \"16378\": 2236,\n \"16382\": 2236,\n \"16394\": 2236,\n \"16395\": 2236,\n- \"164\": [2185, 2186, 2188, 2195, 2197, 2199, 2201, 2210, 2211],\n+ \"164\": [2185, 2186, 2188, 2193, 2195, 2197, 2199, 2201, 2210, 2211],\n \"16402\": 2238,\n \"16405\": 2236,\n \"16406\": 2241,\n \"16409\": 2236,\n \"16413\": 2236,\n \"16417\": 2238,\n \"16442\": 2249,\n@@ -24957,15 +24959,15 @@\n \"17656\": 2265,\n \"1766\": 2199,\n \"176896\": 2207,\n \"17690\": 2241,\n \"17691\": 2249,\n \"17697\": 2246,\n \"1769950\": [182, 760],\n- \"177\": [259, 890, 2185, 2186, 2188, 2193, 2195, 2197, 2199, 2200, 2203, 2210, 2211, 2283, 2298],\n+ \"177\": [259, 890, 2185, 2186, 2188, 2195, 2197, 2199, 2200, 2203, 2210, 2211, 2283, 2298],\n \"17704\": 2238,\n \"177045\": 2186,\n \"17710\": 2238,\n \"17717\": 2241,\n \"17722\": 2241,\n \"177310\": 2207,\n \"17738\": 2238,\n@@ -25679,15 +25681,15 @@\n \"20020101\": 2199,\n \"200252\": 2207,\n \"20027\": 2241,\n \"2002q3\": 540,\n \"2003\": [195, 264, 770, 2199],\n \"20030\": 2241,\n \"200308\": 2207,\n- \"2004\": [107, 629, 1164, 1221, 2219],\n+ \"2004\": [107, 629, 1164, 1221, 2193, 2219],\n \"20040\": 2241,\n \"20040601\": 2219,\n \"20049\": 2246,\n \"2005\": [532, 1345, 1391, 1488, 1490, 1501, 2199, 2202, 2210],\n \"200519\": 2207,\n \"20056\": 2241,\n \"2006\": [107, 532, 629, 1164, 1221, 2191],\n@@ -25748,18 +25750,17 @@\n \"2020q1\": 1008,\n \"2021\": [288, 296, 318, 639, 652, 673, 940, 943, 948, 957, 970, 997, 1542, 2201, 2207, 2213, 2277, 2289, 2294],\n \"2022\": [5, 22, 523, 525, 528, 537, 982, 1185, 1246, 1288, 1491, 1510, 1511, 1512, 1513, 1514, 1515, 1516, 1528, 1529, 1530, 1531, 1532, 1533, 1534, 1542, 1546, 1547, 1548, 1549, 1550, 1551, 1552, 1560, 1564, 1565, 1566, 1567, 1568, 1569, 1570, 1578, 1584, 1585, 1586, 1587, 1588, 1589, 1590, 1598, 1605, 1606, 1607, 1608, 1609, 1610, 1611, 1620, 1624, 1625, 1626, 1627, 1628, 1629, 1630, 1637, 1641, 1642, 1643, 1644, 1645, 1646, 1647, 1657, 1663, 1664, 1665, 1666, 1667, 1668, 1669, 1677, 1684, 1685, 1686, 1687, 1688, 1689, 1690, 1699, 1705, 1706, 1707, 1708, 1709, 1710, 1711, 1720, 1726, 1727, 1728, 1729, 1730, 1731, 1732, 1745, 1746, 1747, 1748, 1749, 1750, 1751, 1758, 1763, 1764, 1765, 1766, 1767, 1768, 1769, 1776, 1780, 1781, 1782, 1783, 1784, 1785, 1786, 1793, 1799, 1800, 1801, 1802, 1803, 1804, 1805, 1815, 1821, 1822, 1823, 1824, 1825, 1826, 1827, 1839, 1844, 1845, 1846, 1847, 1848, 1849, 1850, 1857, 1861, 1862, 1863, 1864, 1865, 1866, 1867, 1876, 1881, 1882, 1883, 1884, 1885, 1886, 1887, 1894, 1899, 1900, 1901, 1902, 1903, 1904, 1905, 1912, 1917, 1918, 1919, 1920, 1921, 1922, 1923, 1930, 1934, 1935, 1936, 1937, 1938, 1939, 1940, 1947, 1951, 1952, 1953, 1954, 1955, 1956, 1957, 1964, 1969, 1970, 1971, 1972, 1973, 1974, 1975, 1982, 1986, 1987, 1988, 1989, 1990, 1991, 1992, 2000, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2018, 2023, 2024, 2025, 2026, 2027, 2028, 2029, 2036, 2041, 2042, 2043, 2044, 2045, 2046, 2047, 2054, 2059, 2060, 2061, 2062, 2063, 2064, 2065, 2077, 2078, 2079, 2080, 2081, 2082, 2083, 2094, 2095, 2096, 2097, 2098, 2099, 2100, 2108, 2112, 2113, 2114, 2115, 2116, 2117, 2118, 2127, 2131, 2132, 2133, 2134, 2135, 2136, 2137, 2145, 2149, 2150, 2151, 2152, 2153, 2154, 2155, 2186, 2203, 2213, 2227, 2298, 2302, 2307],\n \"2022a\": 2294,\n \"2023\": [34, 270, 298, 301, 320, 363, 511, 519, 526, 533, 543, 544, 545, 546, 547, 548, 549, 551, 554, 555, 556, 557, 558, 560, 563, 564, 565, 566, 567, 651, 894, 898, 954, 959, 960, 982, 984, 1000, 1001, 1003, 1004, 1005, 1011, 1016, 1020, 1021, 1024, 1122, 1141, 1147, 1157, 1170, 1171, 1176, 1180, 1185, 1195, 1197, 1206, 1214, 1227, 1228, 1233, 1239, 1245, 1246, 1256, 1258, 1268, 1271, 1273, 1274, 1277, 1278, 1279, 1280, 1282, 1283, 1284, 1285, 1287, 1288, 1290, 1291, 1292, 1293, 1294, 1295, 1297, 1501, 1620, 1930, 2090, 2127, 2145, 2213],\n \"202380\": 2207,\n \"20239\": [2241, 2265],\n- \"2024\": [36, 270, 544, 546, 555, 567, 894, 898, 2127, 2213],\n+ \"2024\": [36, 270, 544, 546, 555, 567, 894, 898, 2127, 2213, 2228],\n \"2025\": [544, 546, 555, 567, 894, 898, 2228],\n \"20251\": 2307,\n- \"2026\": 2228,\n \"202602\": 2205,\n \"202646\": 2230,\n \"20271\": 2241,\n \"202872\": [2184, 2214],\n \"202946\": 2207,\n \"203\": [2185, 2186, 2188, 2195, 2197, 2199, 2210, 2211, 2231, 2253],\n \"2030\": 2265,\n@@ -26605,15 +26606,15 @@\n \"237723\": 2195,\n \"23774\": 2246,\n \"23779\": 2265,\n \"23784\": 2271,\n \"23785\": 2249,\n \"23788\": 2246,\n \"237881\": 2185,\n- \"238\": [2185, 2186, 2188, 2193, 2195, 2197, 2199, 2210, 2220, 2298],\n+ \"238\": [2185, 2186, 2188, 2195, 2197, 2199, 2210, 2220, 2298],\n \"238000\": [2185, 2220],\n \"23801\": 2246,\n \"23803\": 2277,\n \"23807\": 2246,\n \"238075\": 2197,\n \"23809\": 2271,\n \"23814\": 2246,\n@@ -26653,15 +26654,15 @@\n \"23980\": 2246,\n \"239885\": 2186,\n \"23990\": [2246, 2265],\n \"23998\": 2289,\n \"239990\": 2235,\n \"23h30min\": [213, 345, 788, 2210],\n \"24\": [3, 15, 17, 18, 19, 25, 29, 30, 31, 32, 35, 101, 133, 134, 198, 208, 213, 214, 249, 271, 282, 341, 345, 407, 411, 532, 632, 708, 745, 751, 782, 788, 882, 899, 938, 1198, 1202, 1263, 1344, 1397, 1430, 1491, 1506, 1524, 1542, 1560, 2184, 2185, 2186, 2188, 2190, 2191, 2192, 2193, 2194, 2195, 2197, 2198, 2199, 2200, 2201, 2202, 2203, 2204, 2205, 2206, 2207, 2208, 2209, 2210, 2211, 2212, 2214, 2215, 2216, 2218, 2219, 2220, 2222, 2223, 2225, 2226, 2228, 2230, 2231, 2232, 2235, 2238, 2241, 2249, 2265, 2271, 2277, 2283, 2287, 2289, 2294, 2297, 2298, 2302, 2307],\n- \"240\": [1302, 1433, 2185, 2186, 2188, 2193, 2195, 2197, 2199, 2210, 2220, 2231, 2238, 2246, 2298],\n+ \"240\": [1302, 1433, 2185, 2186, 2188, 2195, 2197, 2199, 2210, 2220, 2231, 2238, 2246, 2298],\n \"24008\": 2223,\n \"24009288\": 2199,\n \"24011\": 2249,\n \"24014\": 2249,\n \"24023\": 2246,\n \"24024\": 2246,\n \"24025\": 2246,\n@@ -27455,28 +27456,28 @@\n \"27758\": 2265,\n \"27766\": 2250,\n \"27775\": 2250,\n \"27779\": 2250,\n \"27781\": 2271,\n \"277825\": 2186,\n \"27790\": 2265,\n- \"278\": [2186, 2193, 2195, 2197, 2199, 2210],\n+ \"278\": [2186, 2195, 2197, 2199, 2210],\n \"278094\": 2197,\n \"278111\": 2186,\n \"27814\": 2250,\n \"27837\": 2271,\n \"278380\": 2199,\n \"27840\": 2250,\n \"27841\": 2250,\n \"278445\": 2184,\n \"2786\": 2217,\n \"27865\": 2250,\n \"27874\": 2265,\n \"27892\": 2271,\n- \"279\": [15, 2186, 2193, 2195, 2197, 2199, 2210],\n+ \"279\": [15, 2186, 2195, 2197, 2199, 2210],\n \"27900\": 2251,\n \"279321\": 2186,\n \"279344\": 2186,\n \"27943\": 2250,\n \"27951\": 2265,\n \"27952\": 2265,\n \"27953\": 2271,\n@@ -27514,15 +27515,15 @@\n \"28115\": 2265,\n \"28118\": 2265,\n \"281247\": [2185, 2191, 2197, 2199, 2202, 2204],\n \"28130\": 2265,\n \"28139\": 2265,\n \"281461\": 2191,\n \"28147\": 2251,\n- \"281472434973616\": 2246,\n+ \"281473395739312\": 2246,\n \"28150\": 2265,\n \"28156\": 2271,\n \"28163\": 2265,\n \"2817\": 1344,\n \"281885\": 2186,\n \"28189\": 2271,\n \"28192\": 2265,\n@@ -27572,15 +27573,15 @@\n \"283627\": 2229,\n \"28368\": 2265,\n \"2837\": 2216,\n \"28375\": 2271,\n \"28383\": 2265,\n \"28385\": 2298,\n \"28394\": 2277,\n- \"284\": [16, 17, 18, 19, 2186, 2197, 2199, 2210, 2235],\n+ \"284\": [16, 17, 18, 19, 2186, 2193, 2197, 2199, 2210, 2235],\n \"28406\": 2265,\n \"28410\": 2265,\n \"28425\": 2265,\n \"28426\": 2265,\n \"28427\": 2265,\n \"284319\": 2202,\n \"2846\": 2185,\n@@ -29601,15 +29602,15 @@\n \"386717\": 2207,\n \"38672\": 2283,\n \"386734\": 2207,\n \"386849\": 29,\n \"386902\": 2207,\n \"3869563279212530728\": 2165,\n \"386998\": 2207,\n- \"387\": [16, 17, 18, 19, 2186, 2197, 2199, 2207, 2210, 2235, 2255],\n+ \"387\": [16, 17, 18, 19, 2186, 2193, 2197, 2199, 2207, 2210, 2235, 2255],\n \"38701\": [2294, 2298],\n \"387015\": 2235,\n \"38708\": 2278,\n \"38709\": 2283,\n \"38714\": 2278,\n \"38723\": 2278,\n \"387275\": 2197,\n@@ -30036,15 +30037,15 @@\n \"4056\": 2220,\n \"405638\": 2207,\n \"40571\": 2298,\n \"40585\": 2283,\n \"40589\": 2294,\n \"405906\": 2207,\n \"405919\": 2195,\n- \"406\": [2186, 2199, 2210],\n+ \"406\": [2186, 2193, 2199, 2210],\n \"4060\": 2222,\n \"40606\": 2283,\n \"4062\": [2193, 2217],\n \"40628\": [2283, 2298],\n \"4063\": 2217,\n \"406345\": 2207,\n \"40638\": 2298,\n@@ -30983,15 +30984,15 @@\n \"44564\": 2289,\n \"44572\": 2289,\n \"44574\": 2289,\n \"44575\": 2289,\n \"44580\": 2289,\n \"44595\": 2289,\n \"44597\": 2289,\n- \"446\": [2193, 2199, 2210, 2249],\n+ \"446\": [2199, 2210, 2249],\n \"44603\": 2294,\n \"44609\": 2289,\n \"44616\": 2289,\n \"44629\": 2298,\n \"4463\": 2218,\n \"446531\": 2191,\n \"4466\": 2222,\n@@ -31155,15 +31156,15 @@\n \"45361\": 2294,\n \"45362\": 2294,\n \"453684\": 2207,\n \"453749\": [2184, 2214],\n \"45384\": 2289,\n \"453846\": 2201,\n \"45387\": 2294,\n- \"454\": [28, 2199, 2207, 2210, 2249],\n+ \"454\": [28, 2199, 2207, 2210, 2218, 2249],\n \"454020\": 2207,\n \"45404\": 2294,\n \"454118\": 2207,\n \"454131\": 2197,\n \"45414\": 2294,\n \"4542\": 28,\n \"454200\": 28,\n@@ -31346,15 +31347,15 @@\n \"46174\": 2294,\n \"46178\": 2302,\n \"4618\": 2218,\n \"46185\": 2294,\n \"46186\": 2294,\n \"46188\": [2294, 2298],\n \"4619\": 2218,\n- \"462\": [2199, 2210, 2256],\n+ \"462\": [2193, 2199, 2210, 2256],\n \"4620\": 2218,\n \"46202\": 2298,\n \"4621\": 2218,\n \"46210\": 2294,\n \"46216\": 2294,\n \"46218\": 2293,\n \"46220\": 2294,\n@@ -31507,15 +31508,14 @@\n \"46995\": 2292,\n \"46997\": 2294,\n \"46999\": 2294,\n \"47\": [17, 19, 213, 345, 788, 924, 985, 1323, 2184, 2185, 2186, 2188, 2190, 2191, 2193, 2194, 2195, 2197, 2199, 2200, 2201, 2202, 2203, 2204, 2206, 2207, 2208, 2209, 2210, 2211, 2212, 2214, 2218, 2220, 2222, 2226, 2228, 2230, 2231, 2232, 2235, 2238, 2241, 2246, 2249, 2265, 2271, 2283],\n \"470\": [29, 2199, 2210],\n \"47003\": 2294,\n \"470054\": 2207,\n- \"470079\": 2228,\n \"4702\": 2218,\n \"47039\": 2292,\n \"47053\": 2292,\n \"47071\": 2293,\n \"47079\": 2294,\n \"4708\": 2218,\n \"47084\": [2292, 2298],\n@@ -31539,22 +31539,21 @@\n \"471593\": 2204,\n \"47172\": 2293,\n \"47177\": 2298,\n \"4718\": 2218,\n \"47188\": 2292,\n \"47196\": 2294,\n \"471992\": 2264,\n- \"472\": [2191, 2199, 2210],\n+ \"472\": [2191, 2193, 2199, 2210],\n \"47203\": 2294,\n \"472035\": [2185, 2197, 2199, 2202, 2204, 2215, 2257],\n \"47207\": 2292,\n \"47209\": 2294,\n \"47215\": 2294,\n \"47216\": 2294,\n- \"472377\": 2228,\n \"47244\": 2298,\n \"47247\": 2294,\n \"47248\": 2305,\n \"4726\": 2218,\n \"472618\": 2191,\n \"47263\": 2294,\n \"47266\": [2294, 2298],\n@@ -31999,15 +31998,15 @@\n \"49581\": 2298,\n \"49583\": 2298,\n \"495931\": 2207,\n \"49594\": 2298,\n \"495941\": 1416,\n \"49596\": 2298,\n \"49599\": 2298,\n- \"496\": [2194, 2199, 2201, 2203, 2210, 2249, 2257, 2283, 2294, 2298, 2307],\n+ \"496\": [2193, 2194, 2199, 2201, 2203, 2210, 2249, 2257, 2283, 2294, 2298, 2307],\n \"49603\": 2298,\n \"496030\": 2207,\n \"49612\": [2297, 2302],\n \"49620\": 2298,\n \"49631\": 2298,\n \"49632\": 2298,\n \"49649\": 2297,\n@@ -32737,15 +32736,15 @@\n \"53258\": 2302,\n \"5326\": 2218,\n \"53265\": 2302,\n \"532779\": 2207,\n \"532785\": 2219,\n \"53291\": 2302,\n \"53295\": 2300,\n- \"533\": [16, 17, 18, 19, 2193, 2199, 2207, 2235],\n+ \"533\": [16, 17, 18, 19, 2199, 2207, 2235],\n \"533026\": 2195,\n \"533145\": 2207,\n \"53325\": 2302,\n \"53326\": 2302,\n \"53328\": 2300,\n \"533340\": 2207,\n \"5334\": 2218,\n@@ -33028,15 +33027,15 @@\n \"5497\": 2219,\n \"549734\": 2207,\n \"54980\": 2303,\n \"54981\": 2303,\n \"549834\": 2207,\n \"54984\": 2307,\n \"54994\": 2307,\n- \"55\": [15, 17, 19, 139, 140, 202, 213, 228, 273, 276, 788, 900, 902, 1174, 1175, 2184, 2185, 2186, 2188, 2190, 2191, 2193, 2195, 2197, 2199, 2200, 2201, 2202, 2203, 2204, 2206, 2207, 2208, 2209, 2210, 2211, 2212, 2214, 2218, 2220, 2222, 2223, 2225, 2226, 2228, 2230, 2231, 2232, 2235, 2238, 2241, 2246, 2249, 2271, 2283, 2302],\n+ \"55\": [15, 17, 19, 139, 140, 202, 213, 228, 273, 276, 788, 900, 902, 1174, 1175, 2184, 2185, 2186, 2188, 2190, 2191, 2193, 2195, 2197, 2199, 2200, 2201, 2202, 2203, 2204, 2205, 2206, 2207, 2208, 2209, 2210, 2211, 2212, 2214, 2218, 2220, 2222, 2223, 2225, 2226, 2228, 2230, 2231, 2232, 2235, 2238, 2241, 2246, 2249, 2271, 2283, 2302],\n \"550\": 2199,\n \"5500\": [6, 25],\n \"55000\": 2303,\n \"550000\": 2212,\n \"55003\": 2303,\n \"55006\": 2303,\n \"55009\": 2307,\n@@ -33610,15 +33609,15 @@\n \"591395\": 2207,\n \"5914\": 2219,\n \"591431\": [2184, 2214],\n \"591538\": 2197,\n \"5917\": 2220,\n \"591710\": 2195,\n \"591863\": 2235,\n- \"592\": 2199,\n+ \"592\": [2199, 2205],\n \"5922\": 2219,\n \"592222\": 2207,\n \"592306\": 2184,\n \"592714\": 2195,\n \"5928\": [2186, 2219],\n \"592886\": 2235,\n \"592951\": 2207,\n@@ -34068,15 +34067,15 @@\n \"646086\": 2207,\n \"6462\": 2220,\n \"6463\": 2220,\n \"6466\": 2220,\n \"646654\": 2207,\n \"646721\": 2207,\n \"646737\": 2207,\n- \"647\": [2199, 2257],\n+ \"647\": [2199, 2205, 2257],\n \"6471\": 2220,\n \"6472\": 2220,\n \"647353\": 2207,\n \"647444\": 2207,\n \"647623\": 2186,\n \"647626\": 2207,\n \"647699\": 2199,\n@@ -34236,15 +34235,15 @@\n \"664\": 2199,\n \"6641\": 2298,\n \"6642\": 2298,\n \"6643\": 2298,\n \"6644\": 2298,\n \"6645\": [2220, 2298],\n \"664592\": 2207,\n- \"665\": [2186, 2199, 2227],\n+ \"665\": [2186, 2199, 2205, 2227],\n \"665170\": 2204,\n \"665314\": 2207,\n \"665382\": 2207,\n \"6655\": 2202,\n \"665572\": 2195,\n \"6656\": 2220,\n \"665737\": 2184,\n@@ -34555,15 +34554,15 @@\n \"6th\": 2298,\n \"7\": [10, 15, 16, 17, 18, 19, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 63, 65, 68, 72, 73, 74, 89, 92, 106, 108, 111, 113, 120, 122, 133, 136, 137, 141, 160, 163, 169, 185, 186, 193, 196, 197, 202, 203, 208, 212, 213, 219, 228, 234, 240, 248, 259, 265, 267, 273, 278, 280, 284, 346, 353, 384, 392, 395, 400, 414, 415, 568, 577, 583, 586, 601, 603, 616, 628, 632, 635, 697, 708, 712, 717, 738, 741, 758, 762, 768, 771, 782, 787, 788, 794, 807, 816, 846, 881, 890, 895, 896, 900, 904, 907, 912, 982, 984, 1073, 1075, 1103, 1147, 1150, 1151, 1153, 1157, 1163, 1165, 1170, 1171, 1173, 1176, 1180, 1185, 1188, 1191, 1193, 1197, 1199, 1200, 1205, 1206, 1209, 1210, 1212, 1214, 1220, 1222, 1227, 1228, 1233, 1239, 1246, 1249, 1252, 1254, 1258, 1260, 1261, 1265, 1267, 1268, 1269, 1270, 1273, 1277, 1278, 1279, 1284, 1288, 1293, 1295, 1297, 1304, 1318, 1320, 1321, 1334, 1335, 1337, 1343, 1347, 1369, 1384, 1397, 1406, 1416, 1430, 1433, 1440, 1446, 1447, 1448, 1454, 1456, 1463, 1478, 1479, 1490, 1699, 1720, 2166, 2184, 2185, 2186, 2187, 2188, 2190, 2191, 2192, 2193, 2194, 2195, 2197, 2198, 2199, 2200, 2201, 2202, 2203, 2204, 2205, 2206, 2207, 2208, 2209, 2210, 2211, 2212, 2214, 2215, 2216, 2217, 2218, 2219, 2220, 2221, 2222, 2223, 2224, 2225, 2226, 2228, 2229, 2230, 2231, 2232, 2235, 2238, 2239, 2240, 2241, 2242, 2243, 2245, 2246, 2247, 2248, 2249, 2264, 2265, 2271, 2277, 2278, 2283, 2286, 2289, 2294, 2298, 2302, 2307],\n \"70\": [15, 17, 19, 74, 188, 189, 583, 764, 765, 1198, 2184, 2185, 2186, 2188, 2191, 2195, 2197, 2199, 2200, 2201, 2202, 2204, 2205, 2207, 2208, 2209, 2210, 2211, 2212, 2218, 2220, 2222, 2226, 2228, 2230, 2232, 2235, 2241, 2246, 2271],\n \"700\": [74, 583, 2199, 2261],\n \"70000\": 2201,\n \"700000\": [1320, 2201],\n \"700301\": 2207,\n- \"701\": [2199, 2218],\n+ \"701\": 2199,\n \"701025\": 2207,\n \"7011\": 2220,\n \"701204\": 2214,\n \"701343\": 2207,\n \"701379\": 2186,\n \"7015\": 2220,\n \"701544\": 2191,\n@@ -34773,15 +34772,15 @@\n \"729\": [16, 17, 18, 19, 2197, 2199, 2231, 2235],\n \"729161\": 2199,\n \"7292\": 2241,\n \"7297\": 2221,\n \"7299\": 2221,\n \"729907\": 2186,\n \"72hr\": 234,\n- \"73\": [15, 17, 2184, 2185, 2186, 2188, 2191, 2195, 2197, 2199, 2200, 2201, 2202, 2204, 2205, 2207, 2208, 2209, 2210, 2211, 2212, 2218, 2220, 2222, 2226, 2228, 2230, 2232, 2235, 2238, 2241, 2246, 2271],\n+ \"73\": [15, 17, 2184, 2185, 2186, 2188, 2191, 2193, 2195, 2197, 2199, 2200, 2201, 2202, 2204, 2205, 2207, 2208, 2209, 2210, 2211, 2212, 2218, 2220, 2222, 2226, 2228, 2230, 2232, 2235, 2238, 2241, 2246, 2271],\n \"730\": [16, 17, 18, 19, 2199, 2235],\n \"7300\": 2221,\n \"730057\": 2195,\n \"7302\": 2221,\n \"7306\": 2221,\n \"7308\": 2294,\n \"730951\": 2257,\n@@ -34850,15 +34849,15 @@\n \"7379\": 2221,\n \"738\": [2199, 2298],\n \"738035\": 2186,\n \"7383\": 2221,\n \"738357\": 2207,\n \"738521\": 1011,\n \"738908\": 2207,\n- \"739\": [2199, 2205, 2298],\n+ \"739\": [2199, 2298],\n \"739013\": 2207,\n \"7391\": 2221,\n \"739185\": 2207,\n \"7394\": 2221,\n \"739537\": 2195,\n \"7398\": 2202,\n \"7399\": 2221,\n@@ -34995,15 +34994,15 @@\n \"757772\": 2207,\n \"758\": [27, 2185, 2298],\n \"758070\": 2207,\n \"758294\": 2191,\n \"7586\": 2221,\n \"758602\": 2207,\n \"7588\": 2231,\n- \"759\": [32, 2205],\n+ \"759\": 32,\n \"759104\": 2185,\n \"7592\": 2221,\n \"759328\": 2199,\n \"759606\": 2199,\n \"759644\": 2222,\n \"7599\": 2228,\n \"75th\": [107, 629, 1164, 1221],\n@@ -35525,27 +35524,27 @@\n \"8281983\": 2199,\n \"828230\": 2191,\n \"828394\": 2199,\n \"828427\": 1339,\n \"8285\": 2225,\n \"8287\": 2232,\n \"828904\": 2191,\n- \"829\": 2193,\n \"8292\": 2232,\n \"829645\": 2207,\n \"829678\": 2191,\n \"829721\": 2212,\n \"83\": [15, 24, 2184, 2185, 2186, 2188, 2191, 2195, 2197, 2199, 2200, 2201, 2202, 2204, 2207, 2208, 2209, 2210, 2211, 2212, 2218, 2222, 2223, 2226, 2228, 2230, 2232, 2235, 2241, 2246, 2271],\n \"8302\": 2224,\n \"8303\": 2222,\n \"830429\": 2207,\n \"8305\": 2222,\n \"830545\": 2199,\n \"8306\": [2243, 2246],\n \"830957\": 2207,\n+ \"831\": 2193,\n \"831269\": 2186,\n \"831973\": 2207,\n \"8325\": [2224, 2228],\n \"832585\": 2204,\n \"8327\": 2226,\n \"832706\": 2207,\n \"833069\": 2207,\n@@ -36297,15 +36296,15 @@\n \"938819\": 2204,\n \"939\": 2230,\n \"939036\": 2207,\n \"939145\": 2207,\n \"939470\": 2199,\n \"939652\": 2207,\n \"9398\": 2225,\n- \"94\": [15, 282, 2184, 2185, 2186, 2188, 2191, 2192, 2193, 2195, 2197, 2199, 2200, 2201, 2202, 2204, 2207, 2208, 2209, 2210, 2211, 2218, 2220, 2222, 2226, 2230, 2232, 2235, 2246],\n+ \"94\": [15, 282, 2184, 2185, 2186, 2188, 2191, 2192, 2195, 2197, 2199, 2200, 2201, 2202, 2204, 2207, 2208, 2209, 2210, 2211, 2218, 2220, 2222, 2226, 2230, 2232, 2235, 2246],\n \"9402\": 2228,\n \"941248\": 2199,\n \"9413\": 2238,\n \"941451\": 2210,\n \"9416\": 2228,\n \"9422\": 2238,\n \"942321\": 2207,\n@@ -36939,15 +36938,15 @@\n \"_get_numeric_data\": 2218,\n \"_get_object_pars\": 2199,\n \"_get_opt\": [2202, 2298],\n \"_get_pyarrow_opt\": [2203, 2298],\n \"_get_root\": 2202,\n \"_get_single_kei\": 2202,\n \"_get_slice_axi\": [2185, 2197],\n- \"_get_valu\": [2185, 2191, 2193, 2194, 2197],\n+ \"_get_valu\": [2185, 2191, 2194, 2197],\n \"_getbool_axi\": [2185, 2197],\n \"_getitem_axi\": [2185, 2197],\n \"_getitem_lowerdim\": [2185, 2197],\n \"_getitem_tupl\": [2185, 2197],\n \"_getitem_tuple_same_dim\": 2185,\n \"_handled_typ\": 1031,\n \"_has_inf\": 2221,\n@@ -37082,15 +37081,15 @@\n \"_validate_integ\": 2197,\n \"_validate_kei\": [2185, 2197],\n \"_validate_nam\": [16, 17, 18, 19, 2199, 2203, 2232, 2235, 2298],\n \"_validate_parse_dates_pres\": 2199,\n \"_validate_tuple_index\": 2197,\n \"_validate_usecols_nam\": 2199,\n \"_validate_validate_kwd\": 2200,\n- \"_valu\": [12, 1031, 2185, 2186, 2191, 2194],\n+ \"_valu\": [12, 1031, 2185, 2186, 2191, 2193, 2194],\n \"_values_for_argsort\": 1031,\n \"_values_for_factor\": [1031, 1039],\n \"_verbose_info\": 2218,\n \"_verify_integr\": 2249,\n \"_where\": 2199,\n \"_window\": 2235,\n \"_wrap_arrai\": 2218,\n@@ -40898,14 +40897,15 @@\n \"interf\": 2265,\n \"interfac\": [2, 10, 12, 13, 16, 17, 18, 19, 40, 77, 119, 695, 914, 1031, 1068, 1090, 2167, 2186, 2199, 2203, 2207, 2210, 2211, 2218, 2220, 2225, 2227, 2228, 2230, 2235, 2246, 2261, 2271, 2298, 2307],\n \"interleav\": 2199,\n \"intermedi\": [7, 2172, 2195, 2205, 2210, 2212, 2253, 2307],\n \"intermix\": 2186,\n \"intern\": [0, 7, 11, 22, 191, 194, 203, 268, 286, 364, 376, 430, 622, 624, 699, 767, 769, 873, 932, 938, 1031, 1044, 1123, 1124, 1140, 1148, 1149, 1203, 1207, 1208, 1213, 1215, 1264, 1280, 1345, 1361, 1364, 1388, 1391, 1422, 1423, 1433, 1469, 1486, 1488, 1490, 1493, 1494, 1495, 1496, 1499, 2186, 2188, 2193, 2194, 2195, 2197, 2202, 2207, 2210, 2213, 2216, 2217, 2219, 2220, 2230, 2232, 2235, 2238, 2246, 2249, 2253, 2261, 2263, 2265, 2267, 2271, 2274, 2277, 2280, 2289, 2293, 2298, 2307],\n \"internal_cach\": 10,\n+ \"internal_valu\": 2193,\n \"internet\": 2,\n \"interoper\": [2167, 2186, 2201, 2203, 2302],\n \"interp1d\": [146, 720, 1280],\n \"interp_\": 2201,\n \"interpol\": [89, 124, 125, 169, 202, 601, 700, 701, 776, 1031, 1190, 1251, 1275, 1314, 1331, 1411, 1446, 1447, 1448, 2186, 2199, 2210, 2214, 2217, 2218, 2219, 2220, 2222, 2228, 2230, 2231, 2235, 2236, 2249, 2250, 2261, 2265, 2271, 2272, 2277, 2283, 2289, 2294, 2298, 2302, 2303, 2304, 2307],\n \"interpret\": [2, 3, 6, 13, 16, 17, 18, 19, 24, 31, 134, 160, 212, 256, 568, 709, 738, 750, 787, 862, 866, 888, 1463, 1469, 1470, 1486, 1487, 2185, 2188, 2197, 2199, 2201, 2202, 2206, 2212, 2214, 2216, 2217, 2218, 2220, 2221, 2222, 2226, 2228, 2232, 2235, 2236, 2238, 2241, 2246, 2249, 2265, 2283, 2294, 2298, 2302],\n \"interrog\": [168, 407, 745],\n"}]}, {"source1": "./usr/share/doc/python-pandas-doc/html/user_guide/advanced.html", "source2": "./usr/share/doc/python-pandas-doc/html/user_guide/advanced.html", "unified_diff": "@@ -1856,25 +1856,25 @@\n In [141]: indexer = np.arange(10000)\n \n In [142]: random.shuffle(indexer)\n \n In [143]: %timeit arr[indexer]\n .....: %timeit arr.take(indexer, axis=0)\n .....: \n-213 us +- 21.2 us per loop (mean +- std. dev. of 7 runs, 10,000 loops each)\n-87.3 us +- 15.3 us per loop (mean +- std. dev. of 7 runs, 10,000 loops each)\n+247 us +- 35.8 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n+107 us +- 10 us per loop (mean +- std. dev. of 7 runs, 10,000 loops each)\n \n \n
In [144]: ser = pd.Series(arr[:, 0])\n \n In [145]: %timeit ser.iloc[indexer]\n .....: %timeit ser.take(indexer)\n .....: \n-189 us +- 53 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n-145 us +- 20.9 us per loop (mean +- std. dev. of 7 runs, 10,000 loops each)\n+187 us +- 32.3 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n+171 us +- 15.1 us per loop (mean +- std. dev. of 7 runs, 10,000 loops each)\n
We have discussed MultiIndex
in the previous sections pretty extensively.\n Documentation about DatetimeIndex
and PeriodIndex
are shown here,\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -1241,23 +1241,23 @@\n In [141]: indexer = np.arange(10000)\n \n In [142]: random.shuffle(indexer)\n \n In [143]: %timeit arr[indexer]\n .....: %timeit arr.take(indexer, axis=0)\n .....:\n-213 us +- 21.2 us per loop (mean +- std. dev. of 7 runs, 10,000 loops each)\n-87.3 us +- 15.3 us per loop (mean +- std. dev. of 7 runs, 10,000 loops each)\n+247 us +- 35.8 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n+107 us +- 10 us per loop (mean +- std. dev. of 7 runs, 10,000 loops each)\n In [144]: ser = pd.Series(arr[:, 0])\n \n In [145]: %timeit ser.iloc[indexer]\n .....: %timeit ser.take(indexer)\n .....:\n-189 us +- 53 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n-145 us +- 20.9 us per loop (mean +- std. dev. of 7 runs, 10,000 loops each)\n+187 us +- 32.3 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n+171 us +- 15.1 us per loop (mean +- std. dev. of 7 runs, 10,000 loops each)\n *\b**\b**\b**\b**\b* I\bIn\bnd\bde\bex\bx t\bty\byp\bpe\bes\bs_\b#\b# *\b**\b**\b**\b**\b*\n We have discussed MultiIndex in the previous sections pretty extensively.\n Documentation about DatetimeIndex and PeriodIndex are shown _\bh_\be_\br_\be, and\n documentation about TimedeltaIndex is found _\bh_\be_\br_\be.\n In the following sub-sections we will highlight some other index types.\n *\b**\b**\b**\b* C\bCa\bat\bte\beg\bgo\bor\bri\bic\bca\bal\blI\bIn\bnd\bde\bex\bx_\b#\b# *\b**\b**\b**\b*\n _\bC_\ba_\bt_\be_\bg_\bo_\br_\bi_\bc_\ba_\bl_\bI_\bn_\bd_\be_\bx is a type of index that is useful for supporting indexing with\n"}]}, {"source1": "./usr/share/doc/python-pandas-doc/html/user_guide/enhancingperf.html", "source2": "./usr/share/doc/python-pandas-doc/html/user_guide/enhancingperf.html", "unified_diff": "@@ -601,31 +601,31 @@\n ...: s += f(a + i * dx)\n ...: return s * dx\n ...: \n \n \n
We achieve our result by using DataFrame.apply()
(row-wise):
In [5]: %timeit df.apply(lambda x: integrate_f(x["a"], x["b"], x["N"]), axis=1)\n-149 ms +- 446 us per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+164 ms +- 38.6 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n
Let\u2019s take a look and see where the time is spent during this operation\n using the prun ipython magic function:
\n# most time consuming 4 calls\n In [6]: %prun -l 4 df.apply(lambda x: integrate_f(x["a"], x["b"], x["N"]), axis=1) # noqa E999\n- 605951 function calls (605933 primitive calls) in 0.279 seconds\n+ 605951 function calls (605933 primitive calls) in 0.472 seconds\n \n Ordered by: internal time\n List reduced from 159 to 4 due to restriction <4>\n \n ncalls tottime percall cumtime percall filename:lineno(function)\n- 1000 0.177 0.000 0.238 0.000 <ipython-input-4-c2a74e076cf0>:1(integrate_f)\n- 552423 0.062 0.000 0.062 0.000 <ipython-input-3-c138bdd570e3>:1(f)\n- 1 0.009 0.009 0.278 0.278 apply.py:1070(apply_series_generator)\n- 1000 0.009 0.000 0.009 0.000 managers.py:2065(set_values)\n+ 1000 0.284 0.000 0.387 0.000 <ipython-input-4-c2a74e076cf0>:1(integrate_f)\n+ 552423 0.104 0.000 0.104 0.000 <ipython-input-3-c138bdd570e3>:1(f)\n+ 1 0.034 0.034 0.462 0.462 apply.py:1070(apply_series_generator)\n+ 3000 0.009 0.000 0.010 0.000 series.py:831(_values)\n
By far the majority of time is spend inside either integrate_f
or f
,\n hence we\u2019ll concentrate our efforts cythonizing these two functions.
In [9]: %timeit df.apply(lambda x: integrate_f_plain(x["a"], x["b"], x["N"]), axis=1)\n-94.3 ms +- 19.6 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+124 ms +- 17.2 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n
This has improved the performance compared to the pure Python approach by one-third.
\nWe can annotate the function variables and return types as well as use cdef
\n@@ -667,36 +667,36 @@\n ....: for i in range(N):\n ....: s += f_typed(a + i * dx)\n ....: return s * dx\n ....: \n \n \n
In [11]: %timeit df.apply(lambda x: integrate_f_typed(x["a"], x["b"], x["N"]), axis=1)\n-10.7 ms +- 1.9 ms per loop (mean +- std. dev. of 7 runs, 100 loops each)\n+11.5 ms +- 1.92 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n
Annotating the functions with C types yields an over ten times performance improvement compared to\n the original Python implementation.
\nWhen re-profiling, time is spent creating a Series
from each row, and calling __getitem__
from both\n the index and the series (three times for each row). These Python function calls are expensive and\n can be improved by passing an np.ndarray
.
In [12]: %prun -l 4 df.apply(lambda x: integrate_f_typed(x["a"], x["b"], x["N"]), axis=1)\n- 52528 function calls (52510 primitive calls) in 0.024 seconds\n+ 52528 function calls (52510 primitive calls) in 0.054 seconds\n \n Ordered by: internal time\n List reduced from 157 to 4 due to restriction <4>\n \n ncalls tottime percall cumtime percall filename:lineno(function)\n- 3000 0.004 0.000 0.015 0.000 series.py:1095(__getitem__)\n- 3000 0.003 0.000 0.007 0.000 series.py:1220(_get_value)\n- 16098 0.002 0.000 0.003 0.000 {built-in method builtins.isinstance}\n- 3000 0.002 0.000 0.003 0.000 base.py:3777(get_loc)\n+ 3000 0.009 0.000 0.009 0.000 managers.py:2004(internal_values)\n+ 1000 0.009 0.000 0.009 0.000 managers.py:2065(set_values)\n+ 3000 0.006 0.000 0.007 0.000 base.py:3777(get_loc)\n+ 16098 0.006 0.000 0.007 0.000 {built-in method builtins.isinstance}\n
In [13]: %%cython\n ....: cimport numpy as np\n ....: import numpy as np\n ....: cdef double f_typed(double x) except? -2:\n ....: return x * (x - 1)\n@@ -731,25 +731,25 @@\n
This implementation creates an array of zeros and inserts the result\n of integrate_f_typed
applied over each row. Looping over an ndarray
is faster\n in Cython than looping over a Series
object.
Since apply_integrate_f
is typed to accept an np.ndarray
, Series.to_numpy()
\n calls are needed to utilize this function.
In [14]: %timeit apply_integrate_f(df["a"].to_numpy(), df["b"].to_numpy(), df["N"].to_numpy())\n-1.25 ms +- 68.6 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n+1.6 ms +- 110 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n
Performance has improved from the prior implementation by almost ten times.
\n \nThe majority of the time is now spent in apply_integrate_f
. Disabling Cython\u2019s boundscheck
\n and wraparound
checks can yield more performance.
In [15]: %prun -l 4 apply_integrate_f(df["a"].to_numpy(), df["b"].to_numpy(), df["N"].to_numpy())\n- 78 function calls in 0.002 seconds\n+ 78 function calls in 0.001 seconds\n \n Ordered by: internal time\n List reduced from 21 to 4 due to restriction <4>\n \n ncalls tottime percall cumtime percall filename:lineno(function)\n 1 0.001 0.001 0.001 0.001 <string>:1(<module>)\n 1 0.000 0.000 0.000 0.000 {method 'disable' of '_lsprof.Profiler' objects}\n@@ -791,15 +791,15 @@\n from /build/reproducible-path/pandas-2.2.3+dfsg/buildtmp/.cache/ipython/cython/_cython_magic_1beb7d842bd69f96ce1bb2d1a0cb43e06025bd15.c:1251:\n /usr/lib/python3/dist-packages/numpy/core/include/numpy/npy_1_7_deprecated_api.h:17:2: warning: #warning "Using deprecated NumPy API, disable it with " "#define NPY_NO_DEPRECATED_API NPY_1_7_API_VERSION" [-Wcpp]\n 17 | #warning "Using deprecated NumPy API, disable it with " \\\n | ^~~~~~~\n
In [17]: %timeit apply_integrate_f_wrap(df["a"].to_numpy(), df["b"].to_numpy(), df["N"].to_numpy())\n-829 us +- 12.3 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n+1.1 ms +- 113 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n
However, a loop indexer i
accessing an invalid location in an array would cause a segfault because memory access isn\u2019t checked.\n For more about boundscheck
and wraparound
, see the Cython docs on\n compiler directives.
DataFrame
. This engine requires the\n optional dependency numexpr
to be installed.\n The 'python'
engine is generally not useful except for testing\n other evaluation engines against it. You will achieve no performance\n benefits using eval()
with engine='python'
and may\n incur a performance hit.
In [40]: %timeit df1 + df2 + df3 + df4\n-34.6 ms +- 6.6 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+21.1 ms +- 1.11 ms per loop (mean +- std. dev. of 7 runs, 100 loops each)\n
In [41]: %timeit pd.eval("df1 + df2 + df3 + df4", engine="python")\n-37.6 ms +- 6.17 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+23.9 ms +- 4.16 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n
DataFrame.eval()
method#In addition to the top level pandas.eval()
function you can also\n evaluate an expression in the \u201ccontext\u201d of a DataFrame
.
In [58]: nrows, ncols = 20000, 100\n \n In [59]: df1, df2, df3, df4 = [pd.DataFrame(np.random.randn(nrows, ncols)) for _ in range(4)]\n
DataFrame
arithmetic:
In [60]: %timeit df1 + df2 + df3 + df4\n-32.5 ms +- 1.94 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+23.5 ms +- 4.58 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n
In [61]: %timeit pd.eval("df1 + df2 + df3 + df4")\n-13.5 ms +- 533 us per loop (mean +- std. dev. of 7 runs, 100 loops each)\n+11.5 ms +- 496 us per loop (mean +- std. dev. of 7 runs, 100 loops each)\n
DataFrame
comparison:
In [62]: %timeit (df1 > 0) & (df2 > 0) & (df3 > 0) & (df4 > 0)\n-53.9 ms +- 7 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+24.1 ms +- 2.23 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n
In [63]: %timeit pd.eval("(df1 > 0) & (df2 > 0) & (df3 > 0) & (df4 > 0)")\n-15.7 ms +- 1.52 ms per loop (mean +- std. dev. of 7 runs, 100 loops each)\n+19.8 ms +- 1.73 ms per loop (mean +- std. dev. of 7 runs, 100 loops each)\n
DataFrame
arithmetic with unaligned axes.
In [64]: s = pd.Series(np.random.randn(50))\n \n In [65]: %timeit df1 + df2 + df3 + df4 + s\n-37.1 ms +- 4.53 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+31.7 ms +- 4.35 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n
In [66]: %timeit pd.eval("df1 + df2 + df3 + df4 + s")\n-13.3 ms +- 240 us per loop (mean +- std. dev. of 7 runs, 100 loops each)\n+13.2 ms +- 406 us per loop (mean +- std. dev. of 7 runs, 100 loops each)\n
Note
\nOperations such as
\n1 and 2 # would parse to 1 & 2, but should evaluate to 2\n 3 or 4 # would parse to 3 | 4, but should evaluate to 3\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -106,33 +106,33 @@\n ...: dx = (b - a) / N\n ...: for i in range(N):\n ...: s += f(a + i * dx)\n ...: return s * dx\n ...:\n We achieve our result by using _\bD_\ba_\bt_\ba_\bF_\br_\ba_\bm_\be_\b._\ba_\bp_\bp_\bl_\by_\b(_\b) (row-wise):\n In [5]: %timeit df.apply(lambda x: integrate_f(x[\"a\"], x[\"b\"], x[\"N\"]), axis=1)\n-149 ms +- 446 us per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+164 ms +- 38.6 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n Let\u2019s take a look and see where the time is spent during this operation using\n the _\bp_\br_\bu_\bn_\b _\bi_\bp_\by_\bt_\bh_\bo_\bn_\b _\bm_\ba_\bg_\bi_\bc_\b _\bf_\bu_\bn_\bc_\bt_\bi_\bo_\bn:\n # most time consuming 4 calls\n In [6]: %prun -l 4 df.apply(lambda x: integrate_f(x[\"a\"], x[\"b\"], x[\"N\"]),\n axis=1) # noqa E999\n- 605951 function calls (605933 primitive calls) in 0.279 seconds\n+ 605951 function calls (605933 primitive calls) in 0.472 seconds\n \n Ordered by: internal time\n List reduced from 159 to 4 due to restriction <4>\n \n ncalls tottime percall cumtime percall filename:lineno(function)\n- 1000 0.177 0.000 0.238 0.000 :1\n+ 1000 0.284 0.000 0.387 0.000 :1\n (integrate_f)\n- 552423 0.062 0.000 0.062 0.000 :1\n+ 552423 0.104 0.000 0.104 0.000 :1\n (f)\n- 1 0.009 0.009 0.278 0.278 apply.py:1070\n+ 1 0.034 0.034 0.462 0.462 apply.py:1070\n (apply_series_generator)\n- 1000 0.009 0.000 0.009 0.000 managers.py:2065(set_values)\n+ 3000 0.009 0.000 0.010 0.000 series.py:831(_values)\n By far the majority of time is spend inside either integrate_f or f, hence\n we\u2019ll concentrate our efforts cythonizing these two functions.\n *\b**\b**\b**\b* P\bPl\bla\bai\bin\bn C\bCy\byt\bth\bho\bon\bn_\b#\b# *\b**\b**\b**\b*\n First we\u2019re going to need to import the Cython magic function to IPython:\n In [7]: %load_ext Cython\n Now, let\u2019s simply copy our functions over to Cython:\n In [8]: %%cython\n@@ -143,15 +143,15 @@\n ...: dx = (b - a) / N\n ...: for i in range(N):\n ...: s += f_plain(a + i * dx)\n ...: return s * dx\n ...:\n In [9]: %timeit df.apply(lambda x: integrate_f_plain(x[\"a\"], x[\"b\"], x[\"N\"]),\n axis=1)\n-94.3 ms +- 19.6 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+124 ms +- 17.2 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n This has improved the performance compared to the pure Python approach by one-\n third.\n *\b**\b**\b**\b* D\bDe\bec\bcl\bla\bar\bri\bin\bng\bg C\bC t\bty\byp\bpe\bes\bs_\b#\b# *\b**\b**\b**\b*\n We can annotate the function variables and return types as well as use cdef and\n cpdef to improve performance:\n In [10]: %%cython\n ....: cdef double f_typed(double x) except? -2:\n@@ -163,35 +163,35 @@\n ....: dx = (b - a) / N\n ....: for i in range(N):\n ....: s += f_typed(a + i * dx)\n ....: return s * dx\n ....:\n In [11]: %timeit df.apply(lambda x: integrate_f_typed(x[\"a\"], x[\"b\"], x[\"N\"]),\n axis=1)\n-10.7 ms +- 1.9 ms per loop (mean +- std. dev. of 7 runs, 100 loops each)\n+11.5 ms +- 1.92 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n Annotating the functions with C types yields an over ten times performance\n improvement compared to the original Python implementation.\n *\b**\b**\b**\b* U\bUs\bsi\bin\bng\bg n\bnd\bda\bar\brr\bra\bay\by_\b#\b# *\b**\b**\b**\b*\n When re-profiling, time is spent creating a _\bS_\be_\br_\bi_\be_\bs from each row, and calling\n __getitem__ from both the index and the series (three times for each row).\n These Python function calls are expensive and can be improved by passing an\n np.ndarray.\n In [12]: %prun -l 4 df.apply(lambda x: integrate_f_typed(x[\"a\"], x[\"b\"], x\n [\"N\"]), axis=1)\n- 52528 function calls (52510 primitive calls) in 0.024 seconds\n+ 52528 function calls (52510 primitive calls) in 0.054 seconds\n \n Ordered by: internal time\n List reduced from 157 to 4 due to restriction <4>\n \n ncalls tottime percall cumtime percall filename:lineno(function)\n- 3000 0.004 0.000 0.015 0.000 series.py:1095(__getitem__)\n- 3000 0.003 0.000 0.007 0.000 series.py:1220(_get_value)\n- 16098 0.002 0.000 0.003 0.000 {built-in method\n+ 3000 0.009 0.000 0.009 0.000 managers.py:2004(internal_values)\n+ 1000 0.009 0.000 0.009 0.000 managers.py:2065(set_values)\n+ 3000 0.006 0.000 0.007 0.000 base.py:3777(get_loc)\n+ 16098 0.006 0.000 0.007 0.000 {built-in method\n builtins.isinstance}\n- 3000 0.002 0.000 0.003 0.000 base.py:3777(get_loc)\n In [13]: %%cython\n ....: cimport numpy as np\n ....: import numpy as np\n ....: cdef double f_typed(double x) except? -2:\n ....: return x * (x - 1)\n ....: cpdef double integrate_f_typed(double a, double b, int N):\n ....: cdef int i\n@@ -232,22 +232,22 @@\n This implementation creates an array of zeros and inserts the result of\n integrate_f_typed applied over each row. Looping over an ndarray is faster in\n Cython than looping over a _\bS_\be_\br_\bi_\be_\bs object.\n Since apply_integrate_f is typed to accept an np.ndarray, _\bS_\be_\br_\bi_\be_\bs_\b._\bt_\bo_\b__\bn_\bu_\bm_\bp_\by_\b(_\b)\n calls are needed to utilize this function.\n In [14]: %timeit apply_integrate_f(df[\"a\"].to_numpy(), df[\"b\"].to_numpy(), df\n [\"N\"].to_numpy())\n-1.25 ms +- 68.6 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n+1.6 ms +- 110 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n Performance has improved from the prior implementation by almost ten times.\n *\b**\b**\b**\b* D\bDi\bis\bsa\bab\bbl\bli\bin\bng\bg c\bco\bom\bmp\bpi\bil\ble\ber\br d\bdi\bir\bre\bec\bct\bti\biv\bve\bes\bs_\b#\b# *\b**\b**\b**\b*\n The majority of the time is now spent in apply_integrate_f. Disabling Cython\u2019s\n boundscheck and wraparound checks can yield more performance.\n In [15]: %prun -l 4 apply_integrate_f(df[\"a\"].to_numpy(), df[\"b\"].to_numpy(),\n df[\"N\"].to_numpy())\n- 78 function calls in 0.002 seconds\n+ 78 function calls in 0.001 seconds\n \n Ordered by: internal time\n List reduced from 21 to 4 due to restriction <4>\n \n ncalls tottime percall cumtime percall filename:lineno(function)\n 1 0.001 0.001 0.001 0.001 :1()\n 1 0.000 0.000 0.000 0.000 {method 'disable' of\n@@ -295,15 +295,15 @@\n /usr/lib/python3/dist-packages/numpy/core/include/numpy/\n npy_1_7_deprecated_api.h:17:2: warning: #warning \"Using deprecated NumPy API,\n disable it with \" \"#define NPY_NO_DEPRECATED_API NPY_1_7_API_VERSION\" [-Wcpp]\n 17 | #warning \"Using deprecated NumPy API, disable it with \" \\\n | ^~~~~~~\n In [17]: %timeit apply_integrate_f_wrap(df[\"a\"].to_numpy(), df[\"b\"].to_numpy(),\n df[\"N\"].to_numpy())\n-829 us +- 12.3 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n+1.1 ms +- 113 us per loop (mean +- std. dev. of 7 runs, 1,000 loops each)\n However, a loop indexer i accessing an invalid location in an array would cause\n a segfault because memory access isn\u2019t checked. For more about boundscheck and\n wraparound, see the Cython docs on _\bc_\bo_\bm_\bp_\bi_\bl_\be_\br_\b _\bd_\bi_\br_\be_\bc_\bt_\bi_\bv_\be_\bs.\n *\b**\b**\b**\b**\b* N\bNu\bum\bmb\bba\ba (\b(J\bJI\bIT\bT c\bco\bom\bmp\bpi\bil\bla\bat\bti\bio\bon\bn)\b)_\b#\b# *\b**\b**\b**\b**\b*\n An alternative to statically compiling Cython code is to use a dynamic just-in-\n time (JIT) compiler with _\bN_\bu_\bm_\bb_\ba.\n Numba allows you to write a pure Python function which can be JIT compiled to\n@@ -606,17 +606,17 @@\n The 'numexpr' engine is the more performant engine that can yield performance\n improvements compared to standard Python syntax for large _\bD_\ba_\bt_\ba_\bF_\br_\ba_\bm_\be. This\n engine requires the optional dependency numexpr to be installed.\n The 'python' engine is generally n\bno\bot\bt useful except for testing other evaluation\n engines against it. You will achieve n\bno\bo performance benefits using _\be_\bv_\ba_\bl_\b(_\b) with\n engine='python' and may incur a performance hit.\n In [40]: %timeit df1 + df2 + df3 + df4\n-34.6 ms +- 6.6 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+21.1 ms +- 1.11 ms per loop (mean +- std. dev. of 7 runs, 100 loops each)\n In [41]: %timeit pd.eval(\"df1 + df2 + df3 + df4\", engine=\"python\")\n-37.6 ms +- 6.17 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+23.9 ms +- 4.16 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n *\b**\b**\b**\b* T\bTh\bhe\be _\bD\bD_\ba\ba_\bt\bt_\ba\ba_\bF\bF_\br\br_\ba\ba_\bm\bm_\be\be_\b.\b._\be\be_\bv\bv_\ba\ba_\bl\bl_\b(\b(_\b)\b) m\bme\bet\bth\bho\bod\bd_\b#\b# *\b**\b**\b**\b*\n In addition to the top level _\bp_\ba_\bn_\bd_\ba_\bs_\b._\be_\bv_\ba_\bl_\b(_\b) function you can also evaluate an\n expression in the \u201ccontext\u201d of a _\bD_\ba_\bt_\ba_\bF_\br_\ba_\bm_\be.\n In [42]: df = pd.DataFrame(np.random.randn(5, 2), columns=[\"a\", \"b\"])\n \n In [43]: df.eval(\"a + b\")\n Out[43]:\n@@ -713,29 +713,29 @@\n _\bp_\ba_\bn_\bd_\ba_\bs_\b._\be_\bv_\ba_\bl_\b(_\b) works well with expressions containing large arrays.\n In [58]: nrows, ncols = 20000, 100\n \n In [59]: df1, df2, df3, df4 = [pd.DataFrame(np.random.randn(nrows, ncols)) for\n _ in range(4)]\n _\bD_\ba_\bt_\ba_\bF_\br_\ba_\bm_\be arithmetic:\n In [60]: %timeit df1 + df2 + df3 + df4\n-32.5 ms +- 1.94 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+23.5 ms +- 4.58 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n In [61]: %timeit pd.eval(\"df1 + df2 + df3 + df4\")\n-13.5 ms +- 533 us per loop (mean +- std. dev. of 7 runs, 100 loops each)\n+11.5 ms +- 496 us per loop (mean +- std. dev. of 7 runs, 100 loops each)\n _\bD_\ba_\bt_\ba_\bF_\br_\ba_\bm_\be comparison:\n In [62]: %timeit (df1 > 0) & (df2 > 0) & (df3 > 0) & (df4 > 0)\n-53.9 ms +- 7 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+24.1 ms +- 2.23 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n In [63]: %timeit pd.eval(\"(df1 > 0) & (df2 > 0) & (df3 > 0) & (df4 > 0)\")\n-15.7 ms +- 1.52 ms per loop (mean +- std. dev. of 7 runs, 100 loops each)\n+19.8 ms +- 1.73 ms per loop (mean +- std. dev. of 7 runs, 100 loops each)\n _\bD_\ba_\bt_\ba_\bF_\br_\ba_\bm_\be arithmetic with unaligned axes.\n In [64]: s = pd.Series(np.random.randn(50))\n \n In [65]: %timeit df1 + df2 + df3 + df4 + s\n-37.1 ms +- 4.53 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n+31.7 ms +- 4.35 ms per loop (mean +- std. dev. of 7 runs, 10 loops each)\n In [66]: %timeit pd.eval(\"df1 + df2 + df3 + df4 + s\")\n-13.3 ms +- 240 us per loop (mean +- std. dev. of 7 runs, 100 loops each)\n+13.2 ms +- 406 us per loop (mean +- std. dev. of 7 runs, 100 loops each)\n Note\n Operations such as\n 1 and 2 # would parse to 1 & 2, but should evaluate to 2\n 3 or 4 # would parse to 3 | 4, but should evaluate to 3\n ~1 # this is okay, but slower when using eval\n should be performed in Python. An exception will be raised if you try to\n perform any boolean/bitwise operations with scalar operands that are not of\n"}]}, {"source1": "./usr/share/doc/python-pandas-doc/html/user_guide/scale.html", "source2": "./usr/share/doc/python-pandas-doc/html/user_guide/scale.html", "unified_diff": "@@ -1095,16 +1095,16 @@\n ....: files = pathlib.Path("data/timeseries/").glob("ts*.parquet")\n ....: counts = pd.Series(dtype=int)\n ....: for path in files:\n ....: df = pd.read_parquet(path)\n ....: counts = counts.add(df["name"].value_counts(), fill_value=0)\n ....: counts.astype(int)\n ....: \n-CPU times: user 739 us, sys: 0 ns, total: 739 us\n-Wall time: 759 us\n+CPU times: user 592 us, sys: 55 us, total: 647 us\n+Wall time: 665 us\n Out[32]: Series([], dtype: int64)\n
Some readers, like pandas.read_csv()
, offer parameters to control the\n chunksize
when reading a single file.
Manually chunking is an OK option for workflows that don\u2019t\n require too sophisticated of operations. Some operations, like pandas.DataFrame.groupby()
, are\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -640,16 +640,16 @@\n ....: files = pathlib.Path(\"data/timeseries/\").glob(\"ts*.parquet\")\n ....: counts = pd.Series(dtype=int)\n ....: for path in files:\n ....: df = pd.read_parquet(path)\n ....: counts = counts.add(df[\"name\"].value_counts(), fill_value=0)\n ....: counts.astype(int)\n ....:\n-CPU times: user 739 us, sys: 0 ns, total: 739 us\n-Wall time: 759 us\n+CPU times: user 592 us, sys: 55 us, total: 647 us\n+Wall time: 665 us\n Out[32]: Series([], dtype: int64)\n Some readers, like _\bp_\ba_\bn_\bd_\ba_\bs_\b._\br_\be_\ba_\bd_\b__\bc_\bs_\bv_\b(_\b), offer parameters to control the chunksize\n when reading a single file.\n Manually chunking is an OK option for workflows that don\u2019t require too\n sophisticated of operations. Some operations, like _\bp_\ba_\bn_\bd_\ba_\bs_\b._\bD_\ba_\bt_\ba_\bF_\br_\ba_\bm_\be_\b._\bg_\br_\bo_\bu_\bp_\bb_\by_\b(_\b),\n are much harder to do chunkwise. In these cases, you may be better switching to\n a different library that implements these out-of-core algorithms for you.\n"}]}, {"source1": "./usr/share/doc/python-pandas-doc/html/user_guide/style.ipynb.gz", "source2": "./usr/share/doc/python-pandas-doc/html/user_guide/style.ipynb.gz", "unified_diff": null, "details": [{"source1": "style.ipynb", "source2": "style.ipynb", "unified_diff": null, "details": [{"source1": "Pretty-printed", "source2": "Pretty-printed", "comments": ["Similarity: 0.9985610875706213%", "Differences: {\"'cells'\": \"{1: {'metadata': {'execution': {'iopub.execute_input': '2024-11-06T13:30:01.980846Z', \"", " \"'iopub.status.busy': '2024-11-06T13:30:01.980558Z', 'iopub.status.idle': \"", " \"'2024-11-06T13:30:02.581327Z', 'shell.execute_reply': \"", " \"'2024-11-06T13:30:02.580594Z'}}}, 3: {'metadata': {'execution': \"", " \"{'iopub.execute_input': '2024-11-06T13:30:02.585213Z', 'iopub.status.busy': \"", " \"'2024-11-06T13:30:02.584588Z', 'iopub.status.idle': '2024-11-06T13:30:0 [\u2026]"], "unified_diff": "@@ -39,18 +39,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 1,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2025-12-09T18:24:27.489252Z\",\n- \"iopub.status.busy\": \"2025-12-09T18:24:27.488975Z\",\n- \"iopub.status.idle\": \"2025-12-09T18:24:28.040349Z\",\n- \"shell.execute_reply\": \"2025-12-09T18:24:28.024318Z\"\n+ \"iopub.execute_input\": \"2024-11-06T13:30:01.980846Z\",\n+ \"iopub.status.busy\": \"2024-11-06T13:30:01.980558Z\",\n+ \"iopub.status.idle\": \"2024-11-06T13:30:02.581327Z\",\n+ \"shell.execute_reply\": \"2024-11-06T13:30:02.580594Z\"\n },\n \"nbsphinx\": \"hidden\"\n },\n \"outputs\": [],\n \"source\": [\n \"import matplotlib.pyplot\\n\",\n \"# We have this here to trigger matplotlib's font cache stuff.\\n\",\n@@ -77,36 +77,36 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 2,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2025-12-09T18:24:28.065763Z\",\n- \"iopub.status.busy\": \"2025-12-09T18:24:28.065068Z\",\n- \"iopub.status.idle\": \"2025-12-09T18:24:28.396506Z\",\n- \"shell.execute_reply\": \"2025-12-09T18:24:28.392336Z\"\n+ \"iopub.execute_input\": \"2024-11-06T13:30:02.585213Z\",\n+ \"iopub.status.busy\": \"2024-11-06T13:30:02.584588Z\",\n+ \"iopub.status.idle\": \"2024-11-06T13:30:02.936985Z\",\n+ \"shell.execute_reply\": \"2024-11-06T13:30:02.928588Z\"\n }\n },\n \"outputs\": [],\n \"source\": [\n \"import pandas as pd\\n\",\n \"import numpy as np\\n\",\n \"import matplotlib as mpl\\n\"\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 3,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2025-12-09T18:24:28.413412Z\",\n- \"iopub.status.busy\": \"2025-12-09T18:24:28.413023Z\",\n- \"iopub.status.idle\": \"2025-12-09T18:24:28.540334Z\",\n- \"shell.execute_reply\": \"2025-12-09T18:24:28.524304Z\"\n+ \"iopub.execute_input\": \"2024-11-06T13:30:02.945406Z\",\n+ \"iopub.status.busy\": \"2024-11-06T13:30:02.945030Z\",\n+ \"iopub.status.idle\": \"2024-11-06T13:30:03.016362Z\",\n+ \"shell.execute_reply\": \"2024-11-06T13:30:03.008977Z\"\n },\n \"nbsphinx\": \"hidden\"\n },\n \"outputs\": [],\n \"source\": [\n \"# For reproducibility - this doesn't respect uuid_len or positionally-passed uuid but the places here that use that coincidentally bypass this anyway\\n\",\n \"from pandas.io.formats.style import Styler\\n\",\n@@ -123,18 +123,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 4,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2025-12-09T18:24:28.553416Z\",\n- \"iopub.status.busy\": \"2025-12-09T18:24:28.553030Z\",\n- \"iopub.status.idle\": \"2025-12-09T18:24:28.608322Z\",\n- \"shell.execute_reply\": \"2025-12-09T18:24:28.592305Z\"\n+ \"iopub.execute_input\": \"2024-11-06T13:30:03.028090Z\",\n+ \"iopub.status.busy\": \"2024-11-06T13:30:03.027745Z\",\n+ \"iopub.status.idle\": \"2024-11-06T13:30:03.060465Z\",\n+ \"shell.execute_reply\": \"2024-11-06T13:30:03.056576Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/html\": [\n \"