{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Search space for the 2D matrix of arrays:\n",
      "[Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity'), Real(low=0, high=1, prior='uniform', transform='identity')]\n",
      "Iteration No: 1 started. Evaluating function at random point.\n",
      "Iteration No: 1 ended. Evaluation done at random point.\n",
      "Time taken: 0.0035\n",
      "Function value obtained: -28.9195\n",
      "Current minimum: -28.9195\n",
      "Iteration No: 2 started. Evaluating function at random point.\n",
      "Iteration No: 2 ended. Evaluation done at random point.\n",
      "Time taken: 0.0034\n",
      "Function value obtained: -28.0754\n",
      "Current minimum: -28.9195\n",
      "Iteration No: 3 started. Evaluating function at random point.\n",
      "Iteration No: 3 ended. Evaluation done at random point.\n",
      "Time taken: 0.0037\n",
      "Function value obtained: -34.2365\n",
      "Current minimum: -34.2365\n",
      "Iteration No: 4 started. Evaluating function at random point.\n",
      "Iteration No: 4 ended. Evaluation done at random point.\n",
      "Time taken: 0.0039\n",
      "Function value obtained: -32.9245\n",
      "Current minimum: -34.2365\n",
      "Iteration No: 5 started. Evaluating function at random point.\n",
      "Iteration No: 5 ended. Evaluation done at random point.\n",
      "Time taken: 0.0036\n",
      "Function value obtained: -30.5392\n",
      "Current minimum: -34.2365\n",
      "Iteration No: 6 started. Evaluating function at random point.\n",
      "Iteration No: 6 ended. Evaluation done at random point.\n",
      "Time taken: 0.0031\n",
      "Function value obtained: -31.4877\n",
      "Current minimum: -34.2365\n",
      "Iteration No: 7 started. Evaluating function at random point.\n",
      "Iteration No: 7 ended. Evaluation done at random point.\n",
      "Time taken: 0.0031\n",
      "Function value obtained: -28.6174\n",
      "Current minimum: -34.2365\n",
      "Iteration No: 8 started. Evaluating function at random point.\n",
      "Iteration No: 8 ended. Evaluation done at random point.\n",
      "Time taken: 0.0037\n",
      "Function value obtained: -29.1147\n",
      "Current minimum: -34.2365\n",
      "Iteration No: 9 started. Evaluating function at random point.\n",
      "Iteration No: 9 ended. Evaluation done at random point.\n",
      "Time taken: 0.0036\n",
      "Function value obtained: -28.9138\n",
      "Current minimum: -34.2365\n",
      "Iteration No: 10 started. Evaluating function at random point.\n",
      "Iteration No: 10 ended. Evaluation done at random point.\n",
      "Time taken: 0.6629\n",
      "Function value obtained: -30.5585\n",
      "Current minimum: -34.2365\n",
      "Iteration No: 11 started. Searching for the next optimal point.\n",
      "Iteration No: 11 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.3292\n",
      "Function value obtained: -34.3816\n",
      "Current minimum: -34.3816\n",
      "Iteration No: 12 started. Searching for the next optimal point.\n",
      "Iteration No: 12 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.3976\n",
      "Function value obtained: -28.4065\n",
      "Current minimum: -34.3816\n",
      "Iteration No: 13 started. Searching for the next optimal point.\n",
      "Iteration No: 13 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.6197\n",
      "Function value obtained: -35.5849\n",
      "Current minimum: -35.5849\n",
      "Iteration No: 14 started. Searching for the next optimal point.\n",
      "Iteration No: 14 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.4196\n",
      "Function value obtained: -32.2594\n",
      "Current minimum: -35.5849\n",
      "Iteration No: 15 started. Searching for the next optimal point.\n",
      "Iteration No: 15 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.3431\n",
      "Function value obtained: -30.0500\n",
      "Current minimum: -35.5849\n",
      "Iteration No: 16 started. Searching for the next optimal point.\n",
      "Iteration No: 16 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.3418\n",
      "Function value obtained: -33.5508\n",
      "Current minimum: -35.5849\n",
      "Iteration No: 17 started. Searching for the next optimal point.\n",
      "Iteration No: 17 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.3348\n",
      "Function value obtained: -36.3195\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 18 started. Searching for the next optimal point.\n",
      "Iteration No: 18 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.3696\n",
      "Function value obtained: -33.9338\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 19 started. Searching for the next optimal point.\n",
      "Iteration No: 19 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.3695\n",
      "Function value obtained: -30.5600\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 20 started. Searching for the next optimal point.\n",
      "Iteration No: 20 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.3680\n",
      "Function value obtained: -34.6243\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 21 started. Searching for the next optimal point.\n",
      "Iteration No: 21 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.4044\n",
      "Function value obtained: -35.7112\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 22 started. Searching for the next optimal point.\n",
      "Iteration No: 22 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.4185\n",
      "Function value obtained: -36.2407\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 23 started. Searching for the next optimal point.\n",
      "Iteration No: 23 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.4211\n",
      "Function value obtained: -33.6990\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 24 started. Searching for the next optimal point.\n",
      "Iteration No: 24 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.6422\n",
      "Function value obtained: -33.6080\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 25 started. Searching for the next optimal point.\n",
      "Iteration No: 25 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.4303\n",
      "Function value obtained: -33.8182\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 26 started. Searching for the next optimal point.\n",
      "Iteration No: 26 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.3674\n",
      "Function value obtained: -34.2851\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 27 started. Searching for the next optimal point.\n",
      "Iteration No: 27 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.4296\n",
      "Function value obtained: -34.4319\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 28 started. Searching for the next optimal point.\n",
      "Iteration No: 28 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.4607\n",
      "Function value obtained: -33.9530\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 29 started. Searching for the next optimal point.\n",
      "Iteration No: 29 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.3736\n",
      "Function value obtained: -34.0543\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 30 started. Searching for the next optimal point.\n",
      "Iteration No: 30 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.5239\n",
      "Function value obtained: -29.2083\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 31 started. Searching for the next optimal point.\n",
      "Iteration No: 31 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.5414\n",
      "Function value obtained: -32.1932\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 32 started. Searching for the next optimal point.\n",
      "Iteration No: 32 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.2082\n",
      "Function value obtained: -36.2860\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 33 started. Searching for the next optimal point.\n",
      "Iteration No: 33 ended. Search finished for the next optimal point.\n",
      "Time taken: 2.0441\n",
      "Function value obtained: -26.8455\n",
      "Current minimum: -36.3195\n",
      "Iteration No: 34 started. Searching for the next optimal point.\n",
      "Iteration No: 34 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.6617\n",
      "Function value obtained: -38.3059\n",
      "Current minimum: -38.3059\n",
      "Iteration No: 35 started. Searching for the next optimal point.\n",
      "Iteration No: 35 ended. Search finished for the next optimal point.\n",
      "Time taken: 2.1274\n",
      "Function value obtained: -34.3018\n",
      "Current minimum: -38.3059\n",
      "Iteration No: 36 started. Searching for the next optimal point.\n",
      "Iteration No: 36 ended. Search finished for the next optimal point.\n",
      "Time taken: 2.5766\n",
      "Function value obtained: -35.2499\n",
      "Current minimum: -38.3059\n",
      "Iteration No: 37 started. Searching for the next optimal point.\n",
      "Iteration No: 37 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.6552\n",
      "Function value obtained: -37.7777\n",
      "Current minimum: -38.3059\n",
      "Iteration No: 38 started. Searching for the next optimal point.\n",
      "Iteration No: 38 ended. Search finished for the next optimal point.\n",
      "Time taken: 2.2958\n",
      "Function value obtained: -36.3393\n",
      "Current minimum: -38.3059\n",
      "Iteration No: 39 started. Searching for the next optimal point.\n",
      "Iteration No: 39 ended. Search finished for the next optimal point.\n",
      "Time taken: 2.0938\n",
      "Function value obtained: -39.3764\n",
      "Current minimum: -39.3764\n",
      "Iteration No: 40 started. Searching for the next optimal point.\n",
      "Iteration No: 40 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.5337\n",
      "Function value obtained: -29.3862\n",
      "Current minimum: -39.3764\n",
      "Iteration No: 41 started. Searching for the next optimal point.\n",
      "Iteration No: 41 ended. Search finished for the next optimal point.\n",
      "Time taken: 0.9326\n",
      "Function value obtained: -42.7597\n",
      "Current minimum: -42.7597\n",
      "Iteration No: 42 started. Searching for the next optimal point.\n",
      "Iteration No: 42 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.5187\n",
      "Function value obtained: -32.4067\n",
      "Current minimum: -42.7597\n",
      "Iteration No: 43 started. Searching for the next optimal point.\n",
      "Iteration No: 43 ended. Search finished for the next optimal point.\n",
      "Time taken: 2.8032\n",
      "Function value obtained: -33.3257\n",
      "Current minimum: -42.7597\n",
      "Iteration No: 44 started. Searching for the next optimal point.\n",
      "Iteration No: 44 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.4272\n",
      "Function value obtained: -37.7094\n",
      "Current minimum: -42.7597\n",
      "Iteration No: 45 started. Searching for the next optimal point.\n",
      "Iteration No: 45 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.7964\n",
      "Function value obtained: -33.4538\n",
      "Current minimum: -42.7597\n",
      "Iteration No: 46 started. Searching for the next optimal point.\n",
      "Iteration No: 46 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.6292\n",
      "Function value obtained: -30.7825\n",
      "Current minimum: -42.7597\n",
      "Iteration No: 47 started. Searching for the next optimal point.\n",
      "Iteration No: 47 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.3382\n",
      "Function value obtained: -30.8064\n",
      "Current minimum: -42.7597\n",
      "Iteration No: 48 started. Searching for the next optimal point.\n",
      "Iteration No: 48 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.5807\n",
      "Function value obtained: -38.5923\n",
      "Current minimum: -42.7597\n",
      "Iteration No: 49 started. Searching for the next optimal point.\n",
      "Iteration No: 49 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.3632\n",
      "Function value obtained: -45.3805\n",
      "Current minimum: -45.3805\n",
      "Iteration No: 50 started. Searching for the next optimal point.\n",
      "Iteration No: 50 ended. Search finished for the next optimal point.\n",
      "Time taken: 1.4241\n",
      "Function value obtained: -30.4054\n",
      "Current minimum: -45.3805\n",
      "Best 2D matrix of arrays (D):\n",
      "[[[1.         1.         1.         1.         0.        ]\n",
      "  [0.         1.         1.         0.         1.        ]\n",
      "  [0.         1.         1.         1.         0.        ]\n",
      "  [0.         1.         0.         1.         1.        ]]\n",
      "\n",
      " [[1.         1.         1.         1.         1.        ]\n",
      "  [1.         0.         0.         1.         1.        ]\n",
      "  [1.         1.         0.         0.90491916 1.        ]\n",
      "  [1.         1.         1.         1.         1.        ]]\n",
      "\n",
      " [[0.         1.         0.         1.         1.        ]\n",
      "  [1.         0.         1.         1.         1.        ]\n",
      "  [1.         1.         1.         1.         1.        ]\n",
      "  [0.         1.         1.         0.         1.        ]]]\n",
      "Best objective function value: -45.380493027629186\n",
      "          fun: -45.380493027629186\n",
      "            x: [1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.9049191632486583, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0]\n",
      "    func_vals: [-2.892e+01 -2.808e+01 ... -4.538e+01 -3.041e+01]\n",
      "      x_iters: [[0.6698929771079561, 0.006762237721844923, 0.23598170891360565, 0.002759092877521075, 0.14751476303060088, 0.9310306846579388, 0.22822786702471115, 0.03111939398615638, 0.8943400539834852, 0.7019534442484052, 0.29006447827605647, 0.43083930031154805, 0.1091193677488567, 0.9941873709592003, 0.6938947329710955, 0.2581659946940315, 0.015002129949612034, 0.7236491315210412, 0.013169696733278394, 0.9303542805228929, 0.2218956295957904, 0.7330587609184784, 0.11681036285335303, 0.08393519290912767, 0.9017197644411777, 0.7732284736995091, 0.23791047151231398, 0.048735446771832516, 0.7224492513404301, 0.4942631017741195, 0.6340425006379325, 0.867150466307363, 0.4030953801437338, 0.3666544385552816, 0.7113948176775235, 0.6610432760370768, 0.995095606603646, 0.5010602507045788, 0.16160328338113986, 0.08864388715723127, 0.38928619770731, 0.8076546700500526, 0.3411950524747867, 0.12204583634293989, 0.793564872995359, 0.5288161420026878, 0.25967729925814814, 0.7730204682048749, 0.23033610695151469, 0.21092897152815088, 0.7211113742015035, 0.6743333493429695, 0.20998544507555367, 0.34881256814169564, 0.9899871247296276, 0.1318706898894201, 0.8321506691923338, 0.5508235060734448, 0.8208279677804787, 0.44717968267263264], [0.11306912961655372, 0.930278496673886, 0.9434397693626085, 0.9756360738298928, 0.15729728911544608, 0.32112061760565586, 0.1375555855204578, 0.47382004790443966, 0.21274062458449688, 0.2943356364657245, 0.4992646543679876, 0.07268802809290821, 0.5113657885222064, 0.7801546547418187, 0.8133565808405538, 0.33302822184419295, 0.2685400281328271, 0.466070297969602, 0.03884783423692307, 0.5231527178132145, 0.732311766643078, 0.5592816187750258, 0.346334806619274, 0.4391588634038369, 0.281501199562235, 0.14739212418209427, 0.1238694264194358, 0.5209437589747841, 0.3098668609970258, 0.9012835561619109, 0.8819120161308779, 0.39812102408399785, 0.2346137598549763, 0.5801052763744763, 0.01867316903780414, 0.3042025059690205, 0.16018401417298525, 0.7010089687585164, 0.9278097978859902, 0.9274076838926611, 0.9569655901083116, 0.6591044786505745, 0.37809816975866406, 0.5896794549409603, 0.6377572574125094, 0.572552255454908, 0.9669577037488949, 0.20338431983603217, 0.09409767159981089, 0.14675895114316043, 0.3646293557532792, 0.22437223709673998, 0.3335169972109347, 0.7255022962752926, 0.3266839031748842, 0.7317935225768649, 0.29413593656490694, 0.772427043795835, 0.5913340530317933, 0.8068245522462322], [0.9005762600733034, 0.14237705902051115, 0.5957041528312004, 0.44889034047891396, 0.09062735421112712, 0.2573900289827484, 0.6346646934581761, 0.47035951572848167, 0.41453096969319936, 0.6904590188683383, 0.020221507756136407, 0.6577568067314917, 0.7574496705154429, 0.984490083005396, 0.9505730155069981, 0.8515679573489643, 0.9093844180269216, 0.7543075710691338, 0.34794764253557314, 0.9686507260944329, 0.610829239272161, 0.580540979505451, 0.25148879471195823, 0.9515335548775145, 0.7246066364369087, 0.5011009125743319, 0.6493733576676953, 0.40386866231793583, 0.8004232069101266, 0.2217002561083144, 0.8671261201105028, 0.5333317282397262, 0.1902971944983866, 0.6502376919660456, 0.3540396198807772, 0.8662244989048528, 0.613552591947336, 0.8746128561662234, 0.8394202590872631, 0.7051337264088196, 0.37818234314263377, 0.4390847541098565, 0.4098743265987842, 0.9012769023627707, 0.8854372260917079, 0.9284135266092901, 0.6379759299824889, 0.44878714895818717, 0.7316534442840769, 0.9693368669407467, 0.7319618566919798, 0.4263600563528205, 0.1172658012474447, 0.29987803566585153, 0.5289451957091947, 0.46836813270147315, 0.7558083015535426, 0.09858120754652658, 0.039874606019330024, 0.3060789384831469], [0.8544986268938956, 0.050868715478810236, 0.04146050824331416, 0.6570196793524845, 0.48034070838869647, 0.17980758132164978, 0.21341214625480404, 0.8144572095067295, 0.9108183232647903, 0.0499128076495038, 0.619507534593751, 0.5230246251581355, 0.03578072672078115, 0.7877325353977205, 0.8575263257050493, 0.8752751857818721, 0.7461562201812553, 0.752798724914909, 0.3974230140582746, 0.5220067346792873, 0.9929482471024579, 0.6662812842814171, 0.756153397252213, 0.6936219844664734, 0.8190125718357733, 0.9103906908094926, 0.8680929007366753, 0.7678645151634371, 0.10207940282681607, 0.19638853755971103, 0.4583819038660778, 0.17254577900380588, 0.11605240424299082, 0.1681217713712673, 0.208709684102026, 0.3251268259241937, 0.24472709987230185, 0.7113149178477868, 0.7301429334923039, 0.900877440945516, 0.8355202771633582, 0.7612923418538995, 0.6370608805559584, 0.9756760474775916, 0.6962847024237258, 0.36120893307346463, 0.19399102134508867, 0.23483746893923502, 0.4668267507334255, 0.25754498325987046, 0.3463035280433829, 0.247854971015599, 0.8185163301529513, 0.3803710732596294, 0.40996854656205206, 0.3388186369549641, 0.6311288285747462, 0.8330221908636815, 0.5220731853040986, 0.7277257900436037], [0.9097811265454833, 0.11127327494873498, 0.17112562948097568, 0.5336327987653122, 0.47368333217596137, 0.9053417951114923, 0.731391705019469, 0.35678507861541303, 0.8401997639742874, 0.8676524723370097, 0.7755595452767412, 0.12220551712125241, 0.884699054452217, 0.8071262373737358, 0.5242504446360028, 0.5131021818416175, 0.035150468084897975, 0.5317154263453897, 0.3445778768702587, 0.7401719132082764, 0.8270057609866924, 0.7926452451830963, 0.2930299444085476, 0.8584870818956102, 0.7110519822344136, 0.5003972803784732, 0.003514695427851212, 0.28718420739809686, 0.7280326521893057, 0.3552799727112487, 0.7523949975395535, 0.0792347922592841, 0.78231468182486, 0.05046067687435042, 0.9478946584435245, 0.9788844403614487, 0.06477259037760853, 0.6996117517302943, 0.565343350912885, 0.2561272618514762, 0.3366429453237452, 0.6710597127610393, 0.5554566017869883, 0.24973608032772482, 0.9511930899358063, 0.5310124051565773, 0.10624142190528232, 0.5607781454753459, 0.7838918844387649, 0.18322122287847667, 0.05612665692578224, 0.19574412446960493, 0.47496438855955714, 0.5455213975177405, 0.7404552326655889, 0.6356967395219485, 0.25137830715278925, 0.5983816672864676, 0.9675780528089029, 0.12966084269203407], [0.8774774882061809, 0.3443029988000749, 0.909630876325739, 0.07763589710278297, 0.5390762200339727, 0.9204549650888965, 0.855874014663963, 0.9195287057391139, 0.9278221316079641, 0.1747148786433789, 0.3619572730780258, 0.37227569984087455, 0.6424119342498456, 0.3565467625082503, 0.5266153270010703, 0.2174452935720224, 0.019130886589266764, 0.6094374490375367, 0.10836687253440161, 0.833400893112544, 0.9784633426107104, 0.19146791743491548, 0.34069516301695707, 0.5301073193543648, 0.32968940545428543, 0.9759741406869421, 0.1359871302484771, 0.8255712964367, 0.994837993202089, 0.9275560567904932, 0.7556199976270125, 0.8328689516381226, 0.3420791668458401, 0.4155712835503529, 0.5551683490383977, 0.7706685131852758, 0.2794323386965573, 0.8720675568144128, 0.013388260354522789, 0.4128893879003144, 0.30537641815587774, 0.5214242255823676, 0.061130744563087994, 0.145921846796827, 0.8952631274576711, 0.767909927529418, 0.4332183494069378, 0.9066953582699211, 0.6138752529485146, 0.23073404047848228, 0.8431698254591146, 0.9820693808673228, 0.04177508501659589, 0.18761546354448327, 0.39663093349530576, 0.2164830677240251, 0.21303193809272652, 0.8133909899562833, 0.5150297908527603, 0.09920165337124934], [0.3949892281236429, 0.010726461916658938, 0.5192541856471448, 0.4063292812950917, 0.23217426551883963, 0.9896881979311162, 0.7727695337091725, 0.6782766189668094, 0.2803513152888721, 0.9949465433122845, 0.9660711557319497, 0.022485560193260094, 0.38896404088503134, 0.5181052324847715, 0.9213321908050709, 0.1790465632520997, 0.6873887030568621, 0.289810434589093, 0.3938808624576492, 0.20309016808380648, 0.12371149162475295, 0.5950641912163613, 0.2866386537675571, 0.8826478038652315, 0.5131446601405037, 0.5498560057298568, 0.11366045404521144, 0.047149098476579346, 0.7573429603668153, 0.9998102047298594, 0.2755514333462273, 0.9057068841560377, 0.19186192664221263, 0.029220022665759966, 0.4572920364522136, 0.42175208394541697, 0.049707653687129164, 0.912909281234476, 0.334507817659289, 0.2000925211850612, 0.8006843913476079, 0.26424383735374607, 0.06518419730709747, 0.3082217603507554, 0.6711345637586198, 0.7994008099513928, 0.05838879378946084, 0.7476291486168256, 0.784035328566546, 0.7406716472668968, 0.7513574285437767, 0.9196152063197865, 0.8238889397985675, 0.5056371286598176, 0.04162452323233779, 0.27746521123931017, 0.21403388772153625, 0.3699642858788315, 0.32234531338763256, 0.538076828186458], [0.38428953157117984, 0.5903125525604577, 0.20124858423746855, 0.9394063143144413, 0.7659374791738428, 0.8827842184212851, 0.3278462986402744, 0.8194927886360228, 0.07904422817933, 0.0587632175546995, 0.321710381864254, 0.4564980334109381, 0.24425442011922388, 0.4192881107844523, 0.8483956762413862, 0.3824414945180037, 0.7970457899961277, 0.2823146213780185, 0.4580140614948628, 0.864481126224948, 0.4704611246621372, 0.6729634089134718, 0.11570065730143345, 0.8680689301015381, 0.19694615758488448, 0.6874476150394534, 0.31849687827911605, 0.7836172275218408, 0.89573424270202, 0.506927943805095, 0.45144071307401157, 0.21590779573269298, 0.37773275544360585, 0.6333597771201647, 0.4842599650578966, 0.1367938645258693, 0.18262551261921925, 0.20502710643063776, 0.7270700883229138, 0.750478069640426, 0.8968999318851414, 0.08701451132255879, 0.022860421928801115, 0.7410430856473726, 0.28525089510992424, 0.23823978579019217, 0.45541259577368287, 0.6957487152917541, 0.4847672857314067, 0.21088929823311792, 0.7299195208097058, 0.5444866602293181, 0.3113502697105523, 0.49798077190928447, 0.9741591789874899, 0.19096603242137816, 0.34671083213108195, 0.7072716279221318, 0.07166914487218169, 0.920106504870899], [0.5894555581860885, 0.13939208127987437, 0.8980801739777838, 0.10003458158309567, 0.9310220928672595, 0.6848050562425653, 0.2676833857269331, 0.15649154351971598, 0.27512784501618076, 0.915326781770515, 0.3958935358932899, 0.32109441519821563, 0.026677591767381832, 0.10085589714256007, 0.9220799300240714, 0.5130189851388022, 0.9137984903603903, 0.6311732202393401, 0.5291979965048275, 0.16709988422944536, 0.13555351964864296, 0.9836709136874078, 0.8072333262372655, 0.9561009155718536, 0.6889013511466159, 0.1428470680059635, 0.6105685584653882, 0.691514635553145, 0.17597239947820134, 0.2944643776753257, 0.23332089092632508, 0.6282817026267276, 0.914418967818454, 0.21464504919403699, 0.4526840165481574, 0.26344400407964835, 0.36186023014786145, 0.08512891128936208, 0.22255331024590902, 0.4289233378110734, 0.6786644728895496, 0.2143345320074394, 0.7776399870447276, 0.30976095828514677, 0.978598333325917, 0.9764575333091673, 0.9513729680704561, 0.13305986372463133, 0.12487585067364773, 0.40925935052181206, 0.11392721912986539, 0.2929291555541755, 0.2249117419826388, 0.2641570492266713, 0.5904415592711096, 0.7821184523492193, 0.08996477659635706, 0.8762368046664649, 0.9447793270643511, 0.24440487457163834], [0.9462931012199418, 0.278491622145487, 0.8809001346067454, 0.9029700505933496, 0.1419428138465886, 0.591058017455359, 0.12240257185361994, 0.7042720843099184, 0.9544710514068222, 0.9580769465671845, 0.5317678128711435, 0.44464293466576177, 0.15254491707927878, 0.05411677484574552, 0.12805953010052032, 0.8884498776590807, 0.5562759105753389, 0.026327912404684024, 0.2475444856807571, 0.3279133123196079, 0.7966753529617719, 0.9603978522133451, 0.4876860429349926, 0.137898197417384, 0.6733430313742849, 0.25153808100143277, 0.09568099062119353, 0.8827407772935134, 0.46567023273486985, 0.2839041946586089, 0.26828755209026683, 0.9765129173618415, 0.4679812045780196, 0.26217023219110897, 0.7660229342711584, 0.9766393850111545, 0.8724842337602566, 0.8658298307600861, 0.651175247031986, 0.2387927370754011, 0.8581301085690797, 0.843202317761339, 0.47677919722053386, 0.6673640683515512, 0.5132878316113659, 0.7887094678061533, 0.6505325061139231, 0.510589837135048, 0.25578082049251455, 0.2155712519305059, 0.0638947051225195, 0.5419186701108595, 0.13246428152869918, 0.38511565156233285, 0.24809015246695304, 0.31477326621953466, 0.033343739006737934, 0.4664251968487204, 0.9320394094062101, 0.7601736559435727], [1.0, 0.4645409746977695, 0.6737924458462666, 0.08506907592953361, 1.0, 0.0, 1.0, 1.0, 0.9417837672404459, 0.0, 1.0, 0.38602781469107295, 1.0, 0.7596205788336285, 1.0, 0.843420025279087, 1.0, 1.0, 0.9632803766234831, 0.5158143141925553, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.023900638974985504, 0.0, 0.0, 0.0, 1.0, 0.5266416452586787, 1.0, 0.27655954913056685, 0.0, 0.39353952013041177, 1.0, 1.0, 0.6251867935485073, 0.0, 0.0, 1.0, 0.8415894489893208, 1.0, 0.38687163648763223, 1.0, 0.0, 0.0, 1.0, 0.09196005264274447, 1.0, 0.0, 0.0], [0.9081379194274499, 0.0, 0.18795682731678756, 0.9095798309989946, 0.27123797088137136, 0.0, 0.7082792894495391, 0.8615044694374826, 0.5177971080732299, 0.16661796244224025, 0.0, 0.3463139930392143, 0.09567643902613963, 0.13414662883381914, 1.0, 0.38691934810165673, 0.0, 0.5646090298501788, 0.19782011633861873, 0.7509670304305541, 0.626982449058539, 1.0, 0.8994581924815126, 1.0, 0.02101379067245882, 0.0, 0.35068482916106086, 0.0, 1.0, 0.5748106811810771, 0.08486866801997148, 1.0, 0.8490825498327688, 0.2447448194583207, 0.0, 0.27643020412895564, 0.6699460497933003, 0.9464641730787605, 0.8930065470434173, 0.0, 1.0, 0.5512665719710131, 0.6915251814259523, 0.5254664758237256, 0.8105198589973147, 0.25625196639189957, 0.5605519657205568, 0.5395567118712712, 0.01316616400959728, 0.031226645216730495, 0.8884833346194334, 0.34473964586510475, 0.5947352381375253, 0.8266523114352123, 0.9747200273888161, 0.9839671369685865, 1.0, 0.0, 0.0, 0.4795578076229348], [1.0, 0.0, 0.920538569716485, 0.31399514828607916, 0.0, 0.9261565954279731, 1.0, 0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.4158098076668652, 0.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 0.037582660290006537, 0.0, 1.0, 0.0, 1.0, 1.0, 0.605584427451598, 1.0, 1.0, 1.0, 1.0, 0.9938186671887835, 1.0, 0.0, 0.0, 0.26440259216186557, 0.0, 0.7855127425301186, 0.9964291339111901, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.2844603841945832, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0], [0.5934038093444288, 0.21420062347665475, 0.8988975296250484, 0.2501150613855308, 1.0, 1.0, 0.7282164093915645, 1.0, 0.23039726192350013, 0.401882808158287, 0.0, 1.0, 0.6095471834144023, 0.1085923249633443, 0.0, 0.0, 0.5989452603290253, 0.7438572163805688, 0.5303388183478246, 1.0, 0.2481335198263466, 0.22766317663057217, 0.09976691525768237, 1.0, 0.07751737531029725, 1.0, 1.0, 1.0, 1.0, 0.5278855337679238, 0.14693533563771402, 0.8058733921341001, 0.13112348104457677, 0.8062163936920768, 0.9631563259981565, 0.8584273047942528, 0.5840880723654442, 0.8840500398451093, 0.0, 0.1903360649703882, 0.0, 0.0, 0.0, 0.7198279633742869, 0.14220000099313776, 0.583352487508043, 0.8424478985872048, 0.9570025297387326, 1.0, 1.0, 0.892002526187183, 1.0, 0.3721238617301993, 0.061933374333088397, 0.43896893577986584, 0.23839529023497377, 0.5723625370883969, 0.35187994009978546, 0.0, 0.37767965375907], [0.7377916523260488, 0.12960113616504249, 0.5682197924428171, 0.788043325613023, 0.6295046759767317, 0.9303280451724099, 1.0, 1.0, 0.9195605711662033, 0.0, 0.701797372644942, 0.0, 0.15259099283636401, 0.8467620358845771, 0.8606606598723315, 1.0, 0.4139287664884438, 0.44623257554304346, 0.8801962569429386, 0.2773998302587986, 0.19856233274662366, 0.47595776362365233, 1.0, 0.34848983867518346, 0.04099517926888814, 0.6806690449524497, 1.0, 0.902697292743809, 0.385443359732171, 0.15514563714740873, 0.8403665447814707, 0.9566097813832686, 0.44222533789690255, 0.2766240480593432, 0.15416004610867678, 0.9640680295749687, 0.8238204968599555, 0.014193909649928983, 0.03694476534179254, 0.3502659612089085, 0.0, 0.1636908902563788, 0.0, 0.3756321213041818, 1.0, 0.17511849680338354, 0.6563934427869181, 0.6689918275523518, 1.0, 1.0, 0.7152873496683029, 0.7401487625257509, 0.5379253709255228, 1.0, 0.545106519577234, 0.16297217590041016, 0.7247170307312987, 0.10149188992415659, 0.0, 0.6610680803113426], [1.0, 0.9424955705158837, 0.3460671101020956, 0.5586287965980011, 0.2138858320364772, 0.27659002248832154, 0.22811482944177705, 0.8166923469675957, 1.0, 0.02195653215805154, 0.4415621746337805, 0.35155908997208113, 0.8076638242407269, 0.7266179935241239, 1.0, 1.0, 0.24253249303486552, 0.5438994807428162, 0.04961302362819436, 1.0, 1.0, 0.8024470260970323, 0.733322060848138, 0.6959358102795684, 0.6050159812977507, 0.8438000425113789, 0.2737964376276834, 0.8913609763031399, 0.55091215953178, 0.3102201520550131, 0.3253833753919191, 0.7058647578114671, 0.4101765063581174, 0.1382376321633808, 0.34111278628934155, 0.9990825294447601, 0.51533034986603, 0.24950412141659167, 0.8528272976774035, 1.0, 0.42605427416928704, 1.0, 0.22838281329680746, 0.09459661286858617, 0.20938422876987806, 0.0, 0.41547271296591626, 0.4567014121520503, 1.0, 0.762564817676273, 0.8669450356610927, 0.35192239262979436, 0.3880301743024219, 0.2436400317008846, 0.8591365624421672, 0.31519788362369966, 0.4185066784737672, 0.526296227811121, 0.5729012059037546, 1.0], [1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.8970666866060996, 0.4705276927683328, 0.4731389825472717, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.5430786857644936, 1.0, 0.0, 1.0, 0.27075919894493805, 0.0, 1.0, 0.26860590610473317, 1.0, 0.0, 1.0, 0.8267233649514347, 1.0, 0.0, 1.0, 0.30064127815557473, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.5057181518143694, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0], [0.22205202635511678, 0.6552321416367798, 0.6577737881957927, 0.41772941849654904, 0.35864669439361907, 0.9470563925472726, 0.3018563384572629, 0.34773913373899806, 0.48623434450943076, 0.9157037500340264, 0.10442296251684488, 1.0, 1.0, 0.4534880779396026, 0.7848991339224077, 1.0, 0.4944522839817176, 0.499089273084964, 1.0, 0.7224908664983675, 1.0, 0.7653405529473352, 0.5072201324400524, 0.9301006103673028, 0.6362967655648125, 0.6308627351500539, 0.0, 0.14279627306106935, 0.30565741166690324, 1.0, 0.6776946253750158, 0.0, 0.1902600114930298, 0.1884261824086488, 0.31260305485499085, 0.9058133289262182, 0.7216760376150292, 1.0, 0.0, 0.48059363319955445, 0.7876846632681771, 0.8658632414221359, 1.0, 0.9265859354346389, 0.2542477628091032, 0.9076052931169986, 0.3267929533181123, 0.09145757902073984, 1.0, 0.46974675401262195, 0.9298143234957065, 0.6502097736869841, 0.5319952398931113, 0.0, 0.9150835250365859, 0.6143792664204766, 0.630897178748892, 0.5179020327282242, 0.3235550849309657, 0.5695305891610528], [1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.021166079736724172, 0.6546687613337315, 0.028712775994176418, 0.759485191051838, 1.0, 0.508920337350507, 0.6640186637860516, 1.0, 1.0, 1.0, 0.572093707422851, 0.3002203284601004, 0.3928495319618646, 0.12188086043947499, 0.5795108654209935, 0.9032685445632423, 1.0, 0.05688194448752997, 0.711164919070234, 0.0663727738107178, 0.35437650352945144, 0.2963858659751128, 1.0, 0.5197829182536273, 0.866959594317089, 0.0, 0.4671219820869172, 1.0, 0.0, 0.07658323608954871, 0.7207487259434504, 0.0, 0.0, 0.654934496524083, 0.008315384529454205, 0.6419804975485751, 1.0, 0.8747079760465369, 0.026445495560702276, 0.2706955594475706, 1.0, 0.20309106639426142, 0.5395768458763988, 0.11999904958275798, 1.0, 1.0, 0.0, 0.18057846212266068, 0.6064262942896795, 0.0, 0.7439644790465597, 0.0, 0.32799812343280293], [0.1924590548979033, 0.3647052763584718, 0.23186630036387051, 0.35465978092588996, 0.5086435608626068, 0.0, 0.47061035921042155, 0.41920820619705895, 1.0, 0.5085560998249448, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.2879647772936509, 0.31180360164788723, 0.9214949001942949, 1.0, 0.4089306839798169, 0.48278141789152895, 1.0, 0.6814222357638784, 0.5576527175824226, 0.0, 1.0, 0.6159063444135982, 1.0, 0.6824864221158032, 0.0, 0.0, 0.0, 0.8465639428276355, 1.0, 1.0, 0.2748451791922231, 1.0, 0.0, 1.0, 1.0, 0.8337659046445286, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0, 0.53960796497635, 0.41325941164130164, 0.0, 0.2672104205400798, 1.0, 1.0, 0.9661548599098015, 0.1715422980877703, 1.0], [1.0, 0.5517900498727242, 0.20239291103148027, 0.5370628829249711, 0.7991183227930581, 0.0, 1.0, 0.1784555780064586, 1.0, 0.12325789210963894, 0.6201189962911783, 0.44151664889165587, 0.6740052139702847, 0.6082597249802882, 0.8538174494476448, 1.0, 0.3454361623478042, 0.5584925150952221, 0.2548017874256376, 0.43809566254546356, 1.0, 1.0, 1.0, 0.9533048478382006, 1.0, 0.7210308746101513, 0.5236186679671497, 1.0, 0.0, 0.6146530603008704, 1.0, 0.3420126908551523, 1.0, 0.17158502550464869, 0.0, 0.0, 0.3241210033427012, 0.17780914579904977, 1.0, 1.0, 0.10112541963071923, 0.4785454026370411, 1.0, 1.0, 1.0, 0.7340244872400868, 0.18869045560190953, 0.0, 1.0, 0.6552201056963955, 0.87247849605904, 0.0, 0.4349657231647012, 0.1607510272080959, 1.0, 1.0, 0.9447371807165513, 1.0, 0.2359258355973883, 0.0], [0.8706712590281991, 0.6211253793441066, 0.08896695531935096, 0.08592132999047035, 0.9030680661765279, 0.3990464584937704, 0.4755810789617437, 0.8119241584350038, 0.19113495615610748, 0.5967600139677414, 0.45510788922832807, 0.30940922498980605, 0.19526566319518363, 0.1404652277243545, 1.0, 1.0, 0.8976561787310151, 0.07904056988226897, 0.0, 0.4455798490260066, 1.0, 0.7819856575855924, 0.45231255285781163, 0.0, 0.9583303341936048, 0.7841764020789688, 0.5424443019257995, 0.6821034802679107, 1.0, 0.0, 1.0, 0.6403183596618519, 0.6061816353560773, 0.3521964763751379, 0.9062407854851812, 0.0752207624046006, 0.6727836906825824, 0.47137967256846613, 0.28797342643281154, 0.12380141019230576, 0.9495183771509182, 0.30748432813101795, 0.8207804852460779, 1.0, 1.0, 0.4856846660018626, 0.9863645025273656, 0.8394313944333421, 1.0, 0.7566489563091212, 0.7581182482653053, 1.0, 0.8019583693384206, 0.14982967632640198, 0.18862743847228597, 0.0, 1.0, 0.8879279481210008, 0.9786037922594159, 0.2625025010686328], [1.0, 0.740422281912238, 0.24181285854491663, 0.4993596793638767, 0.49450207803230684, 0.6533991510418228, 0.958106568028804, 0.956563790821651, 0.530903394987565, 0.16858092047193832, 0.8915836206285587, 0.26939498026268993, 0.7502513904791386, 0.9651215901203898, 0.6477105393275043, 1.0, 0.9952474971192085, 0.8472430785103812, 0.964121235245271, 0.5018854351420541, 1.0, 0.14366353682489477, 0.2673526384607836, 0.6389701780570067, 0.1282263129271101, 0.5504883789977603, 0.3309967529698951, 0.8275452445341173, 0.3810457024417208, 0.0, 0.656243263526432, 0.5306591212585952, 0.08379743260607417, 1.0, 0.846118835202177, 1.0, 0.0, 1.0, 0.905758521279495, 0.315386007557116, 0.0, 0.07486015974027554, 0.0, 1.0, 1.0, 1.0, 0.9314991724985799, 1.0, 1.0, 0.05271198101691988, 0.4795319751699734, 0.46294560304833354, 0.3908395037639637, 0.18813474093302562, 0.0, 0.04572198418885648, 1.0, 0.3052573744209236, 0.48982100080623625, 0.2820833603935313], [0.40939687179053064, 0.19984591844655397, 0.889632567207864, 1.0, 1.0, 0.5674793822345701, 0.0, 0.0, 0.4540635586591989, 0.0712084262272158, 0.0284486696909155, 1.0, 0.16433383991181885, 0.0, 0.0, 1.0, 0.0, 0.2663233282621482, 0.0, 0.5672958840336408, 0.29147783653599757, 1.0, 0.7356791376250456, 0.725000596344483, 1.0, 0.7844837636175996, 0.6168421455426191, 1.0, 0.16616763856297367, 0.0, 1.0, 1.0, 1.0, 0.9894239246214465, 1.0, 0.9222840671852763, 1.0, 1.0, 1.0, 0.0641810670180914, 0.3705574675559264, 0.29520186961297834, 0.6938826562904641, 1.0, 0.0, 1.0, 0.47238164445269276, 0.0, 1.0, 0.0010440417731954789, 0.23741888172365863, 1.0, 0.1094808251606893, 0.0, 1.0, 0.29466000038167806, 0.4956402118644605, 1.0, 0.6646220938168593, 1.0], [1.0, 0.05448701637553413, 0.160109056927332, 0.0, 0.8086396731624836, 0.0, 0.8090160642430839, 1.0, 0.8124483110211765, 0.5432518541433302, 0.049767064911584155, 0.8814064181242306, 0.0, 0.4184950880581369, 0.7200474594920326, 1.0, 1.0, 0.9201542774063064, 0.1109073858102725, 0.17361452006184178, 1.0, 0.46162374897231795, 0.24027094424493473, 0.6549099317145681, 1.0, 0.4159199882944544, 1.0, 0.07858497996998248, 0.9508923257670973, 0.5039100487299877, 1.0, 0.042199217399593786, 0.37063136114662937, 0.5121671902675919, 0.71082632481364, 0.6552895477159408, 1.0, 0.4353575574731281, 0.3204846062430921, 0.0, 0.2077833805978805, 0.27680286985964364, 0.12374498050841325, 0.6811162146937395, 0.893126721256198, 0.7248504721193241, 0.07240399981376594, 0.39411863163814015, 1.0, 1.0, 1.0, 0.8750959047406356, 1.0, 0.2205119986435816, 0.314202165114334, 0.0, 1.0, 0.8787610230621372, 0.8508789407324421, 0.6999796471122418], [0.789084816170946, 0.7976937236337897, 0.5346883088546784, 0.19553028007486867, 0.12424980294351724, 0.9066421236387746, 0.1574965929596035, 0.5333162308381758, 0.0, 1.0, 0.4481235346580197, 0.0, 1.0, 0.4644374725475392, 0.7795080629923465, 1.0, 0.7897458487596714, 0.0, 0.17586482963891528, 0.9154761968778812, 0.7653885051521415, 1.0, 0.5073809288819972, 0.0, 1.0, 0.5577498400903359, 0.5650973596498282, 0.8824551191918374, 0.930122374227152, 0.0, 0.914247479473614, 0.6267887348211497, 0.5945937926626835, 0.43821141361253824, 0.5358296570918621, 0.053115360267061096, 1.0, 0.7877975135120205, 0.39849167015585185, 0.41958165853351803, 1.0, 1.0, 0.4911975336311837, 1.0, 0.9421527416387864, 0.22406292734165734, 1.0, 1.0, 1.0, 1.0, 0.7078653231435466, 0.3789395856831974, 0.765878377986956, 0.2844960484007051, 0.2984803282010101, 0.4429174454308701, 0.24920588784210462, 0.416915224907934, 1.0, 0.0], [1.0, 0.0, 0.5324344625303746, 0.0, 1.0, 0.0, 0.8629451028255389, 0.5675182134258473, 0.0, 0.8802952485665552, 0.0, 1.0, 0.02293662130146544, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 0.21357431476990577, 1.0, 0.4213716082309157, 0.06718547788641463, 1.0, 0.18827872953579844, 1.0, 0.8852831645894867, 1.0, 0.0, 1.0, 1.0, 0.34367511221603214, 0.5030689574259274, 1.0, 0.0, 1.0, 0.0, 0.10716075640543987, 0.37201972806258604, 0.42085909324922227, 0.0, 1.0, 1.0, 1.0, 0.23664128452689187, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.6967500028642238, 0.0, 1.0, 0.0, 1.0, 0.4774990790451386, 0.6178115347900812, 0.0], [1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 0.4842370246899995, 1.0, 0.07453861273930695, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.6706432179807899, 1.0, 1.0, 1.0, 0.0, 1.0, 0.2748290214171537, 1.0, 1.0, 0.9711582867351161, 0.0], [1.0, 0.9229633752905969, 0.12808305561484382, 0.0, 0.7925833520240544, 0.3625425796599108, 0.1563720533372817, 0.4204797997007337, 0.42024056182548086, 0.22073578415498152, 0.4887281726559902, 0.5553060455400809, 0.585669322109889, 0.0, 1.0, 1.0, 0.5550103246031582, 0.7494344048434511, 0.1352201319294933, 1.0, 1.0, 0.5555005122388619, 0.6399136680704732, 0.49117894284849106, 1.0, 0.670657658747812, 0.737854902638037, 0.8211491813158578, 0.4275856380172235, 0.0, 0.9905214357433257, 0.375532650741469, 1.0, 0.01653863109210175, 0.6406037827145817, 0.2415169850510445, 0.21991794595026956, 0.13698019420530994, 0.11361574820862934, 0.5919179486859489, 0.6604643481721847, 0.3206698277395744, 1.0, 1.0, 0.1873207582088279, 0.6945680610802254, 0.5326380502301851, 0.6992815853661865, 1.0, 1.0, 0.2886010146128493, 0.9249852443022599, 0.0, 0.0, 0.5446614233808513, 0.18682400348733214, 1.0, 0.11115777347811467, 0.5979101795881657, 0.19901028107375063], [0.29000578907309177, 0.12920986513521204, 0.07014451378417935, 0.18283363916044254, 0.6135723287422497, 0.4677147613606759, 0.7820267258218165, 0.4933282297002539, 0.8431189371193508, 0.7422628353588462, 0.05656998407518063, 0.45264290838874277, 0.17589665780608899, 1.0, 0.08251258824855497, 1.0, 0.46346130126841256, 0.06197610844246469, 0.0, 0.6491352597130715, 0.35705986987281485, 0.00448446627454583, 0.18278902864352456, 0.21522443749815118, 0.3625843206448005, 0.716194703378123, 0.9481597706870688, 0.37294626447415175, 0.6947328050297319, 0.5810258427943928, 1.0, 0.7207539409690612, 0.9769530884697788, 0.837127333662699, 0.3954156215143872, 0.27981100061487263, 0.4112071165672557, 0.8346244029168425, 1.0, 0.23515778824039077, 0.19302437337531983, 1.0, 0.789190926625379, 0.0, 1.0, 1.0, 1.0, 0.486833080173384, 1.0, 0.2667491237242362, 1.0, 1.0, 0.4821544539954101, 0.0, 0.04094298926291728, 0.15246416963037723, 0.7280018670036343, 0.37020834685500986, 0.2535138820009586, 0.7813122319158115], [0.7957757210436075, 0.262871581770062, 0.6171957053047881, 0.16174710450018182, 0.7186663581360485, 0.6700094260344185, 0.7209830085976526, 0.33401745603126565, 0.706346955181909, 0.9362773182284195, 0.0, 0.666689492020891, 0.6357468154763726, 0.004196786796806212, 0.3512481013458552, 0.7890132610653116, 0.7600526938504241, 0.23869848504481617, 0.1425893420909402, 0.7772267042022823, 0.11572962604969486, 0.7693895195046404, 0.27908668156552, 0.29022665017754873, 1.0, 0.9261962852805867, 0.5275283274885381, 0.9065506084551143, 0.4947006881728696, 0.6563958234520234, 0.3243910210315851, 0.5176538396342156, 0.47995113591027333, 0.5761948733602735, 0.29462813726042786, 0.6435216086099702, 1.0, 0.2835965992102211, 0.0, 0.0, 0.5627074984953374, 0.21761692088100815, 0.731569484897029, 0.9092237287003276, 1.0, 1.0, 0.7284602438603164, 0.15848924295023892, 1.0, 0.7380420559907566, 0.5463549096594664, 1.0, 0.18010334695211333, 0.0, 0.24568057898515358, 0.30524024720128573, 0.997263644420398, 0.5440270026803594, 0.716803044454587, 0.09344149934613602], [1.0, 1.0, 1.0, 0.17196692078978945, 1.0, 1.0, 1.0, 1.0, 0.45768479565646264, 0.6451448185049581, 1.0, 1.0, 1.0, 0.0, 0.040246236603817306, 0.36581504469051207, 0.6129846406765268, 0.0, 0.6842036700678301, 0.42816403760369326, 1.0, 1.0, 0.8140952431971752, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 0.9622718258472435, 0.0, 1.0, 1.0, 0.273734052845267, 0.0, 0.0, 0.07829432169705561, 0.0, 0.47603784403364596, 0.6823606550313006, 0.006702780024093797, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.6648534878234442, 0.0, 1.0, 0.5936269382694291, 0.0, 1.0, 0.17491732080054218, 0.0], [0.40831100590667585, 0.6561820319859907, 0.384268996809023, 0.8275290338618185, 0.7791409576995019, 0.08498545455663425, 0.6058025679906299, 0.4130128104904008, 1.0, 0.0, 0.03119469346593605, 1.0, 0.04995139052316366, 0.9173416634260736, 0.5140052943188886, 0.6288579907982695, 0.11263235736923201, 0.9806758518566095, 0.0, 0.2752855961459972, 1.0, 0.1889765478159794, 0.4074836445775481, 0.7195901707549562, 1.0, 0.09940603846235463, 0.4630957132948695, 0.6188040708992179, 0.7569404394562095, 0.312860434914484, 0.0, 0.0, 0.16362232741156796, 0.46514568130463485, 0.24300115529255117, 0.4127210841707268, 0.11284061642555697, 0.8437873260995156, 0.23810835588211615, 0.10066432756080343, 0.0, 0.9445000334652696, 0.19248709902240746, 0.24317828187596582, 0.0, 1.0, 0.6146584324639507, 0.0, 1.0, 0.5785830751921655, 0.23472626526489804, 0.0128386321631737, 0.3662782175849848, 0.5324017282250935, 0.7944514285132418, 0.8116384861307461, 1.0, 0.40989831095677576, 0.5447086841103862, 0.5357826233950018], [0.8659689650159396, 0.29480997514932766, 1.0, 0.791308380628802, 0.4814231538146708, 0.31836545803848554, 0.628532839323037, 0.7059460505901421, 0.3950396948684256, 0.9994699142707582, 0.41750819430033714, 0.37876167616337636, 1.0, 0.6207350102617711, 0.6662475120768829, 0.6079899796543379, 0.9627969841852165, 0.23296398171161634, 0.1880254906039134, 0.17716820068106567, 0.23466794350300083, 0.6619449094606796, 0.7083914012596033, 0.36392299310513815, 1.0, 0.9043133866645859, 1.0, 0.3186501457872685, 0.6978856314118963, 0.5442411846764786, 1.0, 1.0, 0.2886819068218721, 0.9925297036371242, 0.7787614022207104, 1.0, 0.6204349197186015, 0.4949345434636425, 1.0, 1.0, 0.007107198080875413, 1.0, 0.627789714683098, 0.1453885001018303, 0.4619084689623027, 1.0, 0.35676288050227195, 0.8920241079124526, 1.0, 1.0, 1.0, 0.3870812211810288, 0.6973611898039488, 0.04144282111251065, 0.4808470822892194, 0.7662066946265611, 1.0, 0.03019098546876202, 0.43905379535748856, 0.6865704737728159], [0.35210410482219295, 0.4206718965611826, 0.43297309469549256, 0.8239081091641188, 0.9703822109682911, 0.4227853238205405, 1.0, 0.33335154727569766, 0.5427700751968197, 0.7800547860883912, 0.9156558962876623, 0.40859035609468947, 1.0, 0.8664542116974278, 0.0, 0.0, 0.013166872676008277, 0.13452786570615735, 0.9841651480340293, 0.6686444148405595, 0.384998455335962, 0.22926527802296248, 0.9548007614067933, 0.47907904993338757, 1.0, 1.0, 0.7147420728321793, 0.7182300294883949, 0.8503342271730069, 0.3530585420564367, 0.0, 1.0, 0.8947260806825867, 0.5777100964287153, 0.6300931095270865, 0.3168148437495414, 1.0, 0.12789233829896499, 1.0, 0.0, 0.0, 0.35143637181515525, 0.1557101845121267, 1.0, 0.5795558478361079, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.3182875081068959, 0.5623202598852207, 1.0, 0.398492425276693, 0.2872801065981781, 1.0, 0.7654506914014664, 0.5192358285702727, 0.2914122930093766], [0.6857338936932342, 0.5955121581361751, 0.721385681573571, 0.5420802220186552, 0.06538993010686818, 0.0, 0.021296684409857023, 0.5408992939041605, 0.08779884878940282, 0.7235950687233433, 0.46525318650644204, 0.21950282889864894, 1.0, 0.0, 0.8118608729984897, 0.25357026761086865, 0.7463523706231143, 0.0, 0.8017545978989301, 0.5608481400529901, 0.0, 1.0, 0.45495443863147594, 0.949016781153515, 1.0, 0.6298903734973842, 0.8058711736812323, 0.06358031764921891, 1.0, 1.0, 1.0, 1.0, 1.0, 0.7489894435378781, 0.5071605253567034, 0.4122117397183745, 0.8592368022571201, 0.5617321900110954, 1.0, 0.0, 0.46561579101152606, 0.46607358901688856, 0.8229123859409382, 0.0, 0.8371876704494385, 0.9729059436200808, 0.5396329230826844, 1.0, 1.0, 1.0, 0.16701275467971277, 0.6347528033995534, 0.9948419652588475, 1.0, 1.0, 0.48208149062391015, 1.0, 0.9998843506555222, 0.5048644825506873, 1.0], [1.0, 0.8207847164262263, 0.5106845436969427, 0.5960040223898622, 0.3417426950288242, 0.14341238605180434, 0.0, 1.0, 0.4483268389356254, 0.6180672257991664, 0.3012936035573566, 0.389728388129168, 1.0, 0.902411656223955, 0.18532398062049701, 0.2623303369563771, 1.0, 0.4754392881895424, 0.7016454147665075, 0.10644778528317063, 0.3656381640801833, 0.571205876943676, 0.8719694224659464, 0.3270103671061969, 1.0, 1.0, 1.0, 0.8118660165335337, 0.5828983987815235, 0.1726765161699452, 1.0, 0.5795760849213626, 0.9592004313652788, 0.44922419490031096, 1.0, 0.9354900160669645, 0.7762841867807148, 0.05795092331646818, 1.0, 0.49077553762132176, 0.0, 0.4390126551619638, 0.43424358299537713, 0.0, 0.13149072841144832, 0.8009068702786456, 0.9346676621253365, 0.8050134212883073, 1.0, 1.0, 1.0, 0.4960572762731625, 0.3531761238138028, 0.9127529616129277, 0.634911317572848, 0.7668640543149232, 1.0, 0.6991416864734605, 0.36351104678824553, 0.7571565813000019], [0.5951134747857251, 0.494495272683078, 1.0, 0.3028689835712309, 0.7363386241832474, 0.5435802020700603, 0.14931040746083585, 0.590001372598043, 0.5319676906655391, 0.8160741553774443, 0.7696548416250986, 0.6817789915118202, 1.0, 0.03759986559693621, 0.8281576299067566, 0.5529637987270126, 0.7319218009002315, 0.2630399048891497, 0.6739153377771895, 0.6817956990991911, 0.7428271018353614, 0.8957522185020256, 0.6649789122082325, 0.2847179643848445, 1.0, 1.0, 1.0, 0.4805272628620172, 0.6460577792088583, 0.5481066725713462, 1.0, 0.22373196690351282, 0.4940023929626427, 1.0, 0.955289771885957, 0.5121955953138915, 1.0, 0.0578502200290108, 0.8313990670589219, 0.8491355623135391, 0.0, 0.9021180355075571, 0.5802828981208847, 0.0, 0.46675470441369565, 0.15976105320594514, 0.0, 0.26807859257136235, 0.9263298541866718, 1.0, 1.0, 0.9868303536434528, 0.30628767453211864, 0.0, 0.04507683172661539, 0.19253251808456934, 0.45173093966447075, 0.6064000124764993, 1.0, 0.8660894133743305], [0.7442652711421478, 0.6099963855367828, 0.45846525016246875, 0.5575079878662451, 0.5322487036049773, 0.14964272966024267, 0.6608619759369718, 0.44613413087223086, 0.7008792147174923, 0.7634025896956367, 0.0, 1.0, 1.0, 0.36432978017466383, 0.4900872420479055, 1.0, 1.0, 0.260901112026385, 0.34851201723435127, 0.07827315689277915, 1.0, 0.7837431121950281, 1.0, 1.0, 1.0, 1.0, 1.0, 0.9809957089097905, 0.8243590555084741, 1.0, 1.0, 1.0, 0.20599889764273516, 0.7580907179587953, 0.5932987864154501, 1.0, 1.0, 0.36728431657873134, 0.5207497822804554, 1.0, 0.0, 0.9187606793420874, 1.0, 0.33660002475710715, 0.18620120348853098, 0.8701734844250405, 0.25275203878193053, 0.5870698634148848, 0.4982583281346208, 0.44126341889960247, 1.0, 0.0, 0.7028347422345288, 0.15287751713321335, 0.803925383415889, 0.9374032516846437, 1.0, 0.3189621237652678, 0.0, 1.0], [0.8430662424337958, 0.0632536234197394, 0.3385647135974677, 0.6142132124058499, 0.8682999589779151, 0.37791007796444587, 0.3406208021993941, 0.18546124950769163, 0.7671497500827906, 0.6753293009944674, 0.5556054229517831, 0.35452655100980374, 0.9806579924512738, 0.0959881335499804, 0.842299990651578, 0.6615613701934464, 0.8339721026446038, 0.006152005232901605, 0.32196056645035426, 0.3369236072057488, 0.5748336804582503, 0.955989374775841, 0.4977818455049652, 0.24963907517140632, 0.11582567527443124, 0.9090717500638245, 0.5659106671833739, 0.9585107177783183, 0.25962838789139003, 0.14143354200436578, 0.24522448084910659, 0.9603889576522746, 0.34546798475990464, 0.9786218587057344, 0.8136455236533986, 0.5766415407382623, 0.6461849354239143, 0.21051132362963337, 0.8381824379086865, 0.3255333364463215, 0.3208783249816471, 0.30944801847629405, 0.8215806973160936, 0.13493112012679512, 0.1133815699951787, 0.43994217101479227, 0.5261588061022335, 0.4984715525800718, 0.5701267832309405, 0.34146167216170126, 0.7519152373640857, 0.41579263072492334, 0.494644183669228, 0.16806778573022343, 0.4610588455822814, 0.7954926691661864, 0.3030451723273296, 0.48750307226695166, 0.24464037841669334, 0.4616955406707347], [1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 0.9334961853167166, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.9167036271629667, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0], [0.4190549184256247, 0.36704081567285335, 0.25124186553724487, 0.0318736026209876, 0.5180665914940553, 0.07908229229342913, 0.3657902626529744, 0.3827971461485862, 0.0071983826396943024, 0.7233349526919669, 0.41655534254642346, 0.112971016002296, 0.0009466038896308595, 0.9133964142473064, 0.8535807409730263, 0.726200870466985, 0.8171100998199812, 0.761274408145673, 0.02065915435633581, 0.6544761632313604, 0.4196031196216786, 0.6635736788858719, 0.8054467372050255, 0.7567416196654152, 0.9559272016612257, 0.987942093529779, 0.8234995608398029, 0.9550421257993507, 0.8437067688488231, 0.6918623994751647, 0.8497787339179443, 0.2899705290448426, 0.16697868242068173, 0.8263987717706059, 0.649849539193041, 0.9538904372884847, 0.744802966545863, 0.9854805018230495, 0.08281628361306227, 0.5516043448992728, 0.30148469201213607, 0.8194075205915328, 0.2772317462044263, 0.7450466770078937, 0.6304517502352838, 0.3437048190061304, 0.831225023505759, 0.01713434873176656, 0.316071167211807, 0.39424274459294384, 0.8029920879553104, 0.5246824887722978, 0.8198765446373926, 0.14745242026297614, 0.45446617466817385, 0.9182311232373425, 0.35674827522981517, 0.8253194003303517, 0.6265798054463718, 0.09196932886717547], [0.0967382802528425, 0.08895845993437747, 0.5772720370099664, 0.8536414685700803, 0.6536891826190169, 0.5961120542383673, 0.30533270526279416, 0.7354256071395261, 0.6922508820436344, 0.46427643014819264, 0.5815261301676192, 0.7097308842627935, 0.8938050761555726, 0.7975277489122704, 0.04195824115269187, 0.6707608791539565, 0.8265345595145083, 0.33230472753426293, 0.6982022739640327, 0.7825939705572751, 0.6481587888370913, 5.967616993751702e-05, 0.9663656667739847, 0.21815927638322136, 0.6533355025212993, 0.8534645324101471, 0.01370437745420228, 0.9965969497175222, 0.9243009809449155, 0.3962489701699632, 0.8212635285249797, 0.4385461260445802, 0.25069484029122874, 0.9927523241190412, 0.8972577635640048, 0.02017041027597966, 0.9309254394563933, 0.9184849658068821, 0.12655951755077557, 0.8873896054175548, 0.04620972225551257, 0.8899497201794792, 0.14351983849920028, 0.8260278662811507, 0.34993986807254623, 0.9932309213485858, 0.4591907842038703, 0.435825141824684, 0.0607099588349075, 0.18767893694031118, 0.8987750412976728, 0.686884754052743, 0.21221374841078972, 0.25097153297068825, 0.9542242485159508, 0.23346562524183617, 0.6955486794489074, 0.7209504066009927, 0.9068558730757369, 0.050953533859450464], [0.9461654277670586, 0.8490447284260888, 0.9883320910786187, 0.7730858773414434, 0.23922171810100262, 0.45515173927939745, 0.8982963797287048, 0.9552449713662295, 0.9419817474800669, 0.8455028566027385, 0.08227809977719737, 0.7014882244652582, 0.43569115625078836, 0.5212104476151863, 0.9210250596903476, 0.033166319274901664, 0.2793004455042631, 0.3066271616104092, 0.3268546020442245, 0.9929750006521649, 0.06329819695096918, 0.4536407671640774, 0.5978086269043646, 0.22244306138661202, 0.8716283124286371, 0.9894661884602584, 0.6723211960087253, 0.29233869574533927, 0.24332681003592455, 0.8974340849705571, 0.5115939003763557, 0.32123569614437947, 0.538358704562306, 0.556360274799645, 0.9564052072563487, 0.11049003214123701, 0.7243028657901827, 0.23940917761855723, 0.9255514895795731, 0.49774690791505016, 0.5015068609879115, 0.5044704390856172, 0.8973460296044367, 0.703304482957468, 0.7582956543911519, 0.7757346022069832, 0.04450565776479632, 0.26422253501285525, 0.02003705739487172, 0.7352948015908048, 0.9989492175000311, 0.4133344679845944, 0.41324255401322796, 0.7506984740671067, 0.7775046935297497, 0.8129907898032248, 0.8579282119587908, 0.8446546090972008, 0.6345237382648317, 0.9661093266420687], [0.27662956185006043, 0.136528345270464, 0.8785661821392733, 0.32836384977808714, 0.22077965514282855, 0.8156415888718733, 0.10109497851163854, 0.9721083785754018, 0.6650300825399752, 0.710928422243321, 0.4228554111470266, 0.8068092753136107, 0.8918412224801949, 0.31998206366616094, 0.7750149324880626, 0.37820325600184534, 0.6874381287216732, 0.07943028746679816, 0.1004655489681027, 0.6445454908369291, 0.45447134133611955, 0.3850557942615984, 0.7465977657713574, 0.1948311301134507, 0.808976993309935, 0.6307890022062502, 0.6191526150260842, 0.33637720495788054, 0.5740886902776376, 0.4261559198848387, 0.9268612784767042, 0.6177968989988376, 0.18252729869068754, 0.15949427069301228, 0.9831841211601168, 0.5864628273452509, 0.7621698504403539, 0.011165489483916826, 0.6151085463419635, 0.5892520862370175, 0.8281820921713996, 0.35521074427002425, 0.8973840551883763, 0.981847394337625, 0.4700622937576966, 0.9149838539676912, 0.8735465168965225, 0.5908244115676339, 0.22211027585576765, 0.13559589058829094, 0.9136106851684104, 0.35333175336544437, 0.39472271450451935, 0.07521107098149839, 0.927836812007577, 0.22196524856214678, 0.5757071530132513, 0.4647298228126837, 0.9014044818707234, 0.4724842668858007], [0.9387938264918072, 0.8882625945548385, 0.9255390038922295, 0.5029535918424464, 0.6160081951609988, 0.8097618431254132, 0.9054470400642242, 0.9850198944758998, 0.5308443066780273, 0.22169071597237638, 0.7743336896755905, 0.579570089052524, 0.27879501185397976, 0.002732650114197322, 0.5694341409074132, 0.45779654635537603, 0.05857407510047609, 0.9762373866957539, 0.6466175077930986, 0.9019405667280814, 0.2907203832193073, 0.6344011196535092, 0.1757955594747738, 0.0727149794953711, 0.2546697016087313, 0.5264168366313928, 0.7787726400805443, 0.0636377919044885, 0.27270924605826, 0.47465684166087796, 0.04310219655876358, 0.8605152510644518, 0.7902326484153379, 0.5228115517346557, 0.930959053568104, 0.002956267309341843, 0.07000860138666067, 0.3667255036658344, 0.6524016094579848, 0.9570144589587752, 0.1505964625372627, 0.9871537315014882, 0.8980304332505764, 0.015478964112294217, 0.32308115201255744, 0.5300792668355201, 0.7540378938909825, 0.36385581868113376, 0.6634170546174608, 0.3058785334826318, 0.9744064331027078, 0.43072111355262654, 0.4672447899023603, 0.34582949506784083, 0.09684747184572831, 0.48964771698072407, 0.940696471755135, 0.5203933449277385, 0.7221230331526565, 0.19842906064658067], [0.9106002244643386, 0.9667999551521544, 0.3404185441539947, 0.8096647082667533, 0.5404277741246474, 0.7840482573038112, 0.02011786764886581, 0.10559958474620004, 0.9533330879737307, 0.6127945201712147, 0.039925098214745554, 0.06849568102960148, 0.9988371969883568, 0.4457241733585756, 0.5042268567253467, 0.2826327677112414, 0.5850770793697526, 0.4297752939766015, 0.6024262070877476, 0.6508143795367556, 0.44004051555076906, 0.47876360252605155, 0.9393048395686673, 0.6443157844814991, 0.937056806704604, 0.14959259486115287, 0.024929162785580224, 0.9772065155118946, 0.7341333251631007, 0.14690165055149743, 0.07699485227836401, 0.4305449940633995, 0.7350757885147622, 0.8407275940696586, 0.7995352607762737, 0.7406622378255011, 0.009106946641956106, 0.7344886305341309, 0.42233016207713303, 0.03707268099723194, 0.114080125645066, 0.13686674894080866, 0.1361641059911262, 0.1647568368960464, 0.9918494479517047, 0.36502431607783875, 0.25626246578928885, 0.45739515959495525, 0.9765012281233361, 0.21972441431533513, 0.9262530513528155, 0.23524091300720645, 0.03599875427088118, 0.050739581090987765, 0.7597563739449168, 0.8282662670849864, 0.9518327718373896, 0.22921964976151782, 0.9742931556421534, 0.8782311013501107], [0.8412253841050844, 0.5387997360306974, 0.9376622743988675, 0.9605480392499521, 0.1755791881334762, 0.21978514116411269, 0.365487416266115, 0.5684627646485104, 0.6709639805229071, 0.8105146233849746, 0.223065959768807, 0.13844894565176927, 0.9626447665834427, 0.814952086076234, 0.7236630459417206, 0.26189059722287206, 0.8410136664387802, 0.645037928752759, 0.2099428430605395, 0.5708215582666888, 0.5589748260558962, 0.9551163823675842, 0.9925201557128874, 0.7167657148779265, 0.38822620525886087, 0.935799633345581, 0.17420039641661214, 0.5800185508502845, 0.05271055480679589, 0.5268664269975054, 0.982463818338826, 0.622083739787335, 0.0973719675295677, 0.718632597968769, 0.4234492588773282, 0.25628738265566714, 0.5245467032265493, 0.8098504157234223, 0.38272299347787286, 0.9339655912944935, 0.8790766758336537, 0.21486830422653896, 0.8320847912519495, 0.8908164278349916, 0.014749775755836584, 0.9686497280029222, 0.8121467266092998, 0.5881168757435881, 0.8730913656463767, 0.42846560417923474, 0.1567332015810178, 0.9063637734893294, 0.9949201348209961, 0.8320446854803618, 0.6215854351960919, 0.7570616233906627, 0.9025267976789777, 0.9914605629666785, 0.9380426461969864, 0.8101609772435437], [1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.9049191632486583, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0], [0.5350125988885319, 0.013634688529458375, 0.674299288642751, 0.8226881120878542, 0.23139542874349778, 0.7808504943582875, 0.023169178294767948, 0.12415282669793429, 0.6464575212102878, 0.819075043432856, 0.3715880521577137, 0.4528786817689039, 0.9486001880697664, 0.489372877294442, 0.8739070388491307, 0.016086825020520838, 0.013166639886664225, 0.3978539780603385, 0.9814076633924014, 0.39429313251502185, 0.6100780088511903, 0.8239962000190405, 0.7714350303993172, 0.015189745486413723, 0.4506150783347963, 0.016153971638763424, 0.20810670667043957, 0.8356828929768515, 0.4457181038018885, 0.2379948583713874, 0.7853246107798715, 0.44620318272448456, 0.0391263674618414, 0.5973854327429781, 0.9317152128491936, 0.01688810614960035, 0.9547666437340241, 0.2294259449232368, 0.47848392697063613, 0.6786757791949488, 0.31796714089814665, 0.7355268768447615, 0.5870812738715624, 0.7651900216968003, 0.2534177542033285, 0.9718166030933117, 0.3763730042344756, 0.6667392440496215, 0.4068873326933572, 0.7266943356017765, 0.8553426098428485, 0.921766556642214, 0.8459294063587465, 0.8639641618610735, 0.18270178860882894, 0.1770208179111892, 0.6706258485877328, 0.6525056184769363, 0.5836860628032156, 0.8977954106969971]]\n",
      "       models: [GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
      "                                        n_restarts_optimizer=2, noise='gaussian',\n",
      "                                        normalize_y=True, random_state=1291256606)]\n",
      "        space: Space([Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      ...,\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                      Real(low=0, high=1, prior='uniform', transform='normalize')])\n",
      " random_state: RandomState(MT19937)\n",
      "        specs:     args:                    func: <function objective at 0x76a00e711630>\n",
      "                                      dimensions: Space([Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         ...,\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
      "                                                         Real(low=0, high=1, prior='uniform', transform='normalize')])\n",
      "                                  base_estimator: GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5),\n",
      "                                                                           n_restarts_optimizer=2, noise='gaussian',\n",
      "                                                                           normalize_y=True, random_state=1291256606)\n",
      "                                         n_calls: 50\n",
      "                                 n_random_starts: None\n",
      "                                n_initial_points: 10\n",
      "                         initial_point_generator: random\n",
      "                                        acq_func: EI\n",
      "                                   acq_optimizer: auto\n",
      "                                              x0: None\n",
      "                                              y0: None\n",
      "                                    random_state: RandomState(MT19937)\n",
      "                                         verbose: True\n",
      "                                        callback: None\n",
      "                                        n_points: 10000\n",
      "                            n_restarts_optimizer: 5\n",
      "                                              xi: 0.01\n",
      "                                           kappa: 1.96\n",
      "                                          n_jobs: 1\n",
      "                                model_queue_size: None\n",
      "                                space_constraint: None\n",
      "               function: base_minimize\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from skopt import gp_minimize\n",
    "from skopt.space import Real\n",
    "\n",
    "# Define the objective function\n",
    "def objective(params):\n",
    "    # params is a flattened version of the 2D matrix with each entry being an n-length array\n",
    "    D = np.array(params).reshape((M, N, n))  # Reshape into 2D matrix of n-length arrays\n",
    "    \n",
    "    # Example of a mock objective function\n",
    "    # Replace with actual model evaluation code\n",
    "    score = -np.sum(D) + np.random.normal(0, 1)  # Example score to minimize\n",
    "    return score\n",
    "\n",
    "M = 3  # Number of rows in the 2D matrix\n",
    "N = 4  # Number of columns in the 2D matrix\n",
    "n = 5  # Length of each array in the matrix\n",
    "\n",
    "# Define the search space for each element in the 2D matrix, where each is an n-length array\n",
    "search_space = []\n",
    "for i in range(M * N * n):\n",
    "    search_space.append(Real(0, 1, name=f'D_{i}'))  # Range for each value in the arrays\n",
    "print(\"Search space for the 2D matrix of arrays:\")\n",
    "print(search_space)\n",
    "# Run Bayesian optimization\n",
    "result = gp_minimize(\n",
    "    func=objective,          # The objective function\n",
    "    dimensions=search_space, # The search space for the hyperparameters\n",
    "    n_calls=50,              # Number of function evaluations\n",
    "    n_initial_points=10,     # Number of random initialization points\n",
    "    acq_func='EI',           # Acquisition function 'Expected Improvement'\n",
    "    verbose=True             # Verbose mode for detailed output\n",
    ")\n",
    "\n",
    "# Extract optimized parameters\n",
    "optimized_params = np.array(result.x).reshape((M, N, n))\n",
    "\n",
    "print(f\"Best 2D matrix of arrays (D):\\n{optimized_params}\")\n",
    "print(f\"Best objective function value: {result.fun}\")\n",
    "\n",
    "# Optionally, display all optimization results\n",
    "print(result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "          fun: -45.380493027629186\n",
       "            x: [1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.9049191632486583, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0]\n",
       "    func_vals: [-2.892e+01 -2.808e+01 ... -4.538e+01 -3.041e+01]\n",
       "      x_iters: [[0.6698929771079561, 0.006762237721844923, 0.23598170891360565, 0.002759092877521075, 0.14751476303060088, 0.9310306846579388, 0.22822786702471115, 0.03111939398615638, 0.8943400539834852, 0.7019534442484052, 0.29006447827605647, 0.43083930031154805, 0.1091193677488567, 0.9941873709592003, 0.6938947329710955, 0.2581659946940315, 0.015002129949612034, 0.7236491315210412, 0.013169696733278394, 0.9303542805228929, 0.2218956295957904, 0.7330587609184784, 0.11681036285335303, 0.08393519290912767, 0.9017197644411777, 0.7732284736995091, 0.23791047151231398, 0.048735446771832516, 0.7224492513404301, 0.4942631017741195, 0.6340425006379325, 0.867150466307363, 0.4030953801437338, 0.3666544385552816, 0.7113948176775235, 0.6610432760370768, 0.995095606603646, 0.5010602507045788, 0.16160328338113986, 0.08864388715723127, 0.38928619770731, 0.8076546700500526, 0.3411950524747867, 0.12204583634293989, 0.793564872995359, 0.5288161420026878, 0.25967729925814814, 0.7730204682048749, 0.23033610695151469, 0.21092897152815088, 0.7211113742015035, 0.6743333493429695, 0.20998544507555367, 0.34881256814169564, 0.9899871247296276, 0.1318706898894201, 0.8321506691923338, 0.5508235060734448, 0.8208279677804787, 0.44717968267263264], [0.11306912961655372, 0.930278496673886, 0.9434397693626085, 0.9756360738298928, 0.15729728911544608, 0.32112061760565586, 0.1375555855204578, 0.47382004790443966, 0.21274062458449688, 0.2943356364657245, 0.4992646543679876, 0.07268802809290821, 0.5113657885222064, 0.7801546547418187, 0.8133565808405538, 0.33302822184419295, 0.2685400281328271, 0.466070297969602, 0.03884783423692307, 0.5231527178132145, 0.732311766643078, 0.5592816187750258, 0.346334806619274, 0.4391588634038369, 0.281501199562235, 0.14739212418209427, 0.1238694264194358, 0.5209437589747841, 0.3098668609970258, 0.9012835561619109, 0.8819120161308779, 0.39812102408399785, 0.2346137598549763, 0.5801052763744763, 0.01867316903780414, 0.3042025059690205, 0.16018401417298525, 0.7010089687585164, 0.9278097978859902, 0.9274076838926611, 0.9569655901083116, 0.6591044786505745, 0.37809816975866406, 0.5896794549409603, 0.6377572574125094, 0.572552255454908, 0.9669577037488949, 0.20338431983603217, 0.09409767159981089, 0.14675895114316043, 0.3646293557532792, 0.22437223709673998, 0.3335169972109347, 0.7255022962752926, 0.3266839031748842, 0.7317935225768649, 0.29413593656490694, 0.772427043795835, 0.5913340530317933, 0.8068245522462322], [0.9005762600733034, 0.14237705902051115, 0.5957041528312004, 0.44889034047891396, 0.09062735421112712, 0.2573900289827484, 0.6346646934581761, 0.47035951572848167, 0.41453096969319936, 0.6904590188683383, 0.020221507756136407, 0.6577568067314917, 0.7574496705154429, 0.984490083005396, 0.9505730155069981, 0.8515679573489643, 0.9093844180269216, 0.7543075710691338, 0.34794764253557314, 0.9686507260944329, 0.610829239272161, 0.580540979505451, 0.25148879471195823, 0.9515335548775145, 0.7246066364369087, 0.5011009125743319, 0.6493733576676953, 0.40386866231793583, 0.8004232069101266, 0.2217002561083144, 0.8671261201105028, 0.5333317282397262, 0.1902971944983866, 0.6502376919660456, 0.3540396198807772, 0.8662244989048528, 0.613552591947336, 0.8746128561662234, 0.8394202590872631, 0.7051337264088196, 0.37818234314263377, 0.4390847541098565, 0.4098743265987842, 0.9012769023627707, 0.8854372260917079, 0.9284135266092901, 0.6379759299824889, 0.44878714895818717, 0.7316534442840769, 0.9693368669407467, 0.7319618566919798, 0.4263600563528205, 0.1172658012474447, 0.29987803566585153, 0.5289451957091947, 0.46836813270147315, 0.7558083015535426, 0.09858120754652658, 0.039874606019330024, 0.3060789384831469], [0.8544986268938956, 0.050868715478810236, 0.04146050824331416, 0.6570196793524845, 0.48034070838869647, 0.17980758132164978, 0.21341214625480404, 0.8144572095067295, 0.9108183232647903, 0.0499128076495038, 0.619507534593751, 0.5230246251581355, 0.03578072672078115, 0.7877325353977205, 0.8575263257050493, 0.8752751857818721, 0.7461562201812553, 0.752798724914909, 0.3974230140582746, 0.5220067346792873, 0.9929482471024579, 0.6662812842814171, 0.756153397252213, 0.6936219844664734, 0.8190125718357733, 0.9103906908094926, 0.8680929007366753, 0.7678645151634371, 0.10207940282681607, 0.19638853755971103, 0.4583819038660778, 0.17254577900380588, 0.11605240424299082, 0.1681217713712673, 0.208709684102026, 0.3251268259241937, 0.24472709987230185, 0.7113149178477868, 0.7301429334923039, 0.900877440945516, 0.8355202771633582, 0.7612923418538995, 0.6370608805559584, 0.9756760474775916, 0.6962847024237258, 0.36120893307346463, 0.19399102134508867, 0.23483746893923502, 0.4668267507334255, 0.25754498325987046, 0.3463035280433829, 0.247854971015599, 0.8185163301529513, 0.3803710732596294, 0.40996854656205206, 0.3388186369549641, 0.6311288285747462, 0.8330221908636815, 0.5220731853040986, 0.7277257900436037], [0.9097811265454833, 0.11127327494873498, 0.17112562948097568, 0.5336327987653122, 0.47368333217596137, 0.9053417951114923, 0.731391705019469, 0.35678507861541303, 0.8401997639742874, 0.8676524723370097, 0.7755595452767412, 0.12220551712125241, 0.884699054452217, 0.8071262373737358, 0.5242504446360028, 0.5131021818416175, 0.035150468084897975, 0.5317154263453897, 0.3445778768702587, 0.7401719132082764, 0.8270057609866924, 0.7926452451830963, 0.2930299444085476, 0.8584870818956102, 0.7110519822344136, 0.5003972803784732, 0.003514695427851212, 0.28718420739809686, 0.7280326521893057, 0.3552799727112487, 0.7523949975395535, 0.0792347922592841, 0.78231468182486, 0.05046067687435042, 0.9478946584435245, 0.9788844403614487, 0.06477259037760853, 0.6996117517302943, 0.565343350912885, 0.2561272618514762, 0.3366429453237452, 0.6710597127610393, 0.5554566017869883, 0.24973608032772482, 0.9511930899358063, 0.5310124051565773, 0.10624142190528232, 0.5607781454753459, 0.7838918844387649, 0.18322122287847667, 0.05612665692578224, 0.19574412446960493, 0.47496438855955714, 0.5455213975177405, 0.7404552326655889, 0.6356967395219485, 0.25137830715278925, 0.5983816672864676, 0.9675780528089029, 0.12966084269203407], [0.8774774882061809, 0.3443029988000749, 0.909630876325739, 0.07763589710278297, 0.5390762200339727, 0.9204549650888965, 0.855874014663963, 0.9195287057391139, 0.9278221316079641, 0.1747148786433789, 0.3619572730780258, 0.37227569984087455, 0.6424119342498456, 0.3565467625082503, 0.5266153270010703, 0.2174452935720224, 0.019130886589266764, 0.6094374490375367, 0.10836687253440161, 0.833400893112544, 0.9784633426107104, 0.19146791743491548, 0.34069516301695707, 0.5301073193543648, 0.32968940545428543, 0.9759741406869421, 0.1359871302484771, 0.8255712964367, 0.994837993202089, 0.9275560567904932, 0.7556199976270125, 0.8328689516381226, 0.3420791668458401, 0.4155712835503529, 0.5551683490383977, 0.7706685131852758, 0.2794323386965573, 0.8720675568144128, 0.013388260354522789, 0.4128893879003144, 0.30537641815587774, 0.5214242255823676, 0.061130744563087994, 0.145921846796827, 0.8952631274576711, 0.767909927529418, 0.4332183494069378, 0.9066953582699211, 0.6138752529485146, 0.23073404047848228, 0.8431698254591146, 0.9820693808673228, 0.04177508501659589, 0.18761546354448327, 0.39663093349530576, 0.2164830677240251, 0.21303193809272652, 0.8133909899562833, 0.5150297908527603, 0.09920165337124934], [0.3949892281236429, 0.010726461916658938, 0.5192541856471448, 0.4063292812950917, 0.23217426551883963, 0.9896881979311162, 0.7727695337091725, 0.6782766189668094, 0.2803513152888721, 0.9949465433122845, 0.9660711557319497, 0.022485560193260094, 0.38896404088503134, 0.5181052324847715, 0.9213321908050709, 0.1790465632520997, 0.6873887030568621, 0.289810434589093, 0.3938808624576492, 0.20309016808380648, 0.12371149162475295, 0.5950641912163613, 0.2866386537675571, 0.8826478038652315, 0.5131446601405037, 0.5498560057298568, 0.11366045404521144, 0.047149098476579346, 0.7573429603668153, 0.9998102047298594, 0.2755514333462273, 0.9057068841560377, 0.19186192664221263, 0.029220022665759966, 0.4572920364522136, 0.42175208394541697, 0.049707653687129164, 0.912909281234476, 0.334507817659289, 0.2000925211850612, 0.8006843913476079, 0.26424383735374607, 0.06518419730709747, 0.3082217603507554, 0.6711345637586198, 0.7994008099513928, 0.05838879378946084, 0.7476291486168256, 0.784035328566546, 0.7406716472668968, 0.7513574285437767, 0.9196152063197865, 0.8238889397985675, 0.5056371286598176, 0.04162452323233779, 0.27746521123931017, 0.21403388772153625, 0.3699642858788315, 0.32234531338763256, 0.538076828186458], [0.38428953157117984, 0.5903125525604577, 0.20124858423746855, 0.9394063143144413, 0.7659374791738428, 0.8827842184212851, 0.3278462986402744, 0.8194927886360228, 0.07904422817933, 0.0587632175546995, 0.321710381864254, 0.4564980334109381, 0.24425442011922388, 0.4192881107844523, 0.8483956762413862, 0.3824414945180037, 0.7970457899961277, 0.2823146213780185, 0.4580140614948628, 0.864481126224948, 0.4704611246621372, 0.6729634089134718, 0.11570065730143345, 0.8680689301015381, 0.19694615758488448, 0.6874476150394534, 0.31849687827911605, 0.7836172275218408, 0.89573424270202, 0.506927943805095, 0.45144071307401157, 0.21590779573269298, 0.37773275544360585, 0.6333597771201647, 0.4842599650578966, 0.1367938645258693, 0.18262551261921925, 0.20502710643063776, 0.7270700883229138, 0.750478069640426, 0.8968999318851414, 0.08701451132255879, 0.022860421928801115, 0.7410430856473726, 0.28525089510992424, 0.23823978579019217, 0.45541259577368287, 0.6957487152917541, 0.4847672857314067, 0.21088929823311792, 0.7299195208097058, 0.5444866602293181, 0.3113502697105523, 0.49798077190928447, 0.9741591789874899, 0.19096603242137816, 0.34671083213108195, 0.7072716279221318, 0.07166914487218169, 0.920106504870899], [0.5894555581860885, 0.13939208127987437, 0.8980801739777838, 0.10003458158309567, 0.9310220928672595, 0.6848050562425653, 0.2676833857269331, 0.15649154351971598, 0.27512784501618076, 0.915326781770515, 0.3958935358932899, 0.32109441519821563, 0.026677591767381832, 0.10085589714256007, 0.9220799300240714, 0.5130189851388022, 0.9137984903603903, 0.6311732202393401, 0.5291979965048275, 0.16709988422944536, 0.13555351964864296, 0.9836709136874078, 0.8072333262372655, 0.9561009155718536, 0.6889013511466159, 0.1428470680059635, 0.6105685584653882, 0.691514635553145, 0.17597239947820134, 0.2944643776753257, 0.23332089092632508, 0.6282817026267276, 0.914418967818454, 0.21464504919403699, 0.4526840165481574, 0.26344400407964835, 0.36186023014786145, 0.08512891128936208, 0.22255331024590902, 0.4289233378110734, 0.6786644728895496, 0.2143345320074394, 0.7776399870447276, 0.30976095828514677, 0.978598333325917, 0.9764575333091673, 0.9513729680704561, 0.13305986372463133, 0.12487585067364773, 0.40925935052181206, 0.11392721912986539, 0.2929291555541755, 0.2249117419826388, 0.2641570492266713, 0.5904415592711096, 0.7821184523492193, 0.08996477659635706, 0.8762368046664649, 0.9447793270643511, 0.24440487457163834], [0.9462931012199418, 0.278491622145487, 0.8809001346067454, 0.9029700505933496, 0.1419428138465886, 0.591058017455359, 0.12240257185361994, 0.7042720843099184, 0.9544710514068222, 0.9580769465671845, 0.5317678128711435, 0.44464293466576177, 0.15254491707927878, 0.05411677484574552, 0.12805953010052032, 0.8884498776590807, 0.5562759105753389, 0.026327912404684024, 0.2475444856807571, 0.3279133123196079, 0.7966753529617719, 0.9603978522133451, 0.4876860429349926, 0.137898197417384, 0.6733430313742849, 0.25153808100143277, 0.09568099062119353, 0.8827407772935134, 0.46567023273486985, 0.2839041946586089, 0.26828755209026683, 0.9765129173618415, 0.4679812045780196, 0.26217023219110897, 0.7660229342711584, 0.9766393850111545, 0.8724842337602566, 0.8658298307600861, 0.651175247031986, 0.2387927370754011, 0.8581301085690797, 0.843202317761339, 0.47677919722053386, 0.6673640683515512, 0.5132878316113659, 0.7887094678061533, 0.6505325061139231, 0.510589837135048, 0.25578082049251455, 0.2155712519305059, 0.0638947051225195, 0.5419186701108595, 0.13246428152869918, 0.38511565156233285, 0.24809015246695304, 0.31477326621953466, 0.033343739006737934, 0.4664251968487204, 0.9320394094062101, 0.7601736559435727], [1.0, 0.4645409746977695, 0.6737924458462666, 0.08506907592953361, 1.0, 0.0, 1.0, 1.0, 0.9417837672404459, 0.0, 1.0, 0.38602781469107295, 1.0, 0.7596205788336285, 1.0, 0.843420025279087, 1.0, 1.0, 0.9632803766234831, 0.5158143141925553, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.023900638974985504, 0.0, 0.0, 0.0, 1.0, 0.5266416452586787, 1.0, 0.27655954913056685, 0.0, 0.39353952013041177, 1.0, 1.0, 0.6251867935485073, 0.0, 0.0, 1.0, 0.8415894489893208, 1.0, 0.38687163648763223, 1.0, 0.0, 0.0, 1.0, 0.09196005264274447, 1.0, 0.0, 0.0], [0.9081379194274499, 0.0, 0.18795682731678756, 0.9095798309989946, 0.27123797088137136, 0.0, 0.7082792894495391, 0.8615044694374826, 0.5177971080732299, 0.16661796244224025, 0.0, 0.3463139930392143, 0.09567643902613963, 0.13414662883381914, 1.0, 0.38691934810165673, 0.0, 0.5646090298501788, 0.19782011633861873, 0.7509670304305541, 0.626982449058539, 1.0, 0.8994581924815126, 1.0, 0.02101379067245882, 0.0, 0.35068482916106086, 0.0, 1.0, 0.5748106811810771, 0.08486866801997148, 1.0, 0.8490825498327688, 0.2447448194583207, 0.0, 0.27643020412895564, 0.6699460497933003, 0.9464641730787605, 0.8930065470434173, 0.0, 1.0, 0.5512665719710131, 0.6915251814259523, 0.5254664758237256, 0.8105198589973147, 0.25625196639189957, 0.5605519657205568, 0.5395567118712712, 0.01316616400959728, 0.031226645216730495, 0.8884833346194334, 0.34473964586510475, 0.5947352381375253, 0.8266523114352123, 0.9747200273888161, 0.9839671369685865, 1.0, 0.0, 0.0, 0.4795578076229348], [1.0, 0.0, 0.920538569716485, 0.31399514828607916, 0.0, 0.9261565954279731, 1.0, 0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.4158098076668652, 0.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 0.037582660290006537, 0.0, 1.0, 0.0, 1.0, 1.0, 0.605584427451598, 1.0, 1.0, 1.0, 1.0, 0.9938186671887835, 1.0, 0.0, 0.0, 0.26440259216186557, 0.0, 0.7855127425301186, 0.9964291339111901, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.2844603841945832, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0], [0.5934038093444288, 0.21420062347665475, 0.8988975296250484, 0.2501150613855308, 1.0, 1.0, 0.7282164093915645, 1.0, 0.23039726192350013, 0.401882808158287, 0.0, 1.0, 0.6095471834144023, 0.1085923249633443, 0.0, 0.0, 0.5989452603290253, 0.7438572163805688, 0.5303388183478246, 1.0, 0.2481335198263466, 0.22766317663057217, 0.09976691525768237, 1.0, 0.07751737531029725, 1.0, 1.0, 1.0, 1.0, 0.5278855337679238, 0.14693533563771402, 0.8058733921341001, 0.13112348104457677, 0.8062163936920768, 0.9631563259981565, 0.8584273047942528, 0.5840880723654442, 0.8840500398451093, 0.0, 0.1903360649703882, 0.0, 0.0, 0.0, 0.7198279633742869, 0.14220000099313776, 0.583352487508043, 0.8424478985872048, 0.9570025297387326, 1.0, 1.0, 0.892002526187183, 1.0, 0.3721238617301993, 0.061933374333088397, 0.43896893577986584, 0.23839529023497377, 0.5723625370883969, 0.35187994009978546, 0.0, 0.37767965375907], [0.7377916523260488, 0.12960113616504249, 0.5682197924428171, 0.788043325613023, 0.6295046759767317, 0.9303280451724099, 1.0, 1.0, 0.9195605711662033, 0.0, 0.701797372644942, 0.0, 0.15259099283636401, 0.8467620358845771, 0.8606606598723315, 1.0, 0.4139287664884438, 0.44623257554304346, 0.8801962569429386, 0.2773998302587986, 0.19856233274662366, 0.47595776362365233, 1.0, 0.34848983867518346, 0.04099517926888814, 0.6806690449524497, 1.0, 0.902697292743809, 0.385443359732171, 0.15514563714740873, 0.8403665447814707, 0.9566097813832686, 0.44222533789690255, 0.2766240480593432, 0.15416004610867678, 0.9640680295749687, 0.8238204968599555, 0.014193909649928983, 0.03694476534179254, 0.3502659612089085, 0.0, 0.1636908902563788, 0.0, 0.3756321213041818, 1.0, 0.17511849680338354, 0.6563934427869181, 0.6689918275523518, 1.0, 1.0, 0.7152873496683029, 0.7401487625257509, 0.5379253709255228, 1.0, 0.545106519577234, 0.16297217590041016, 0.7247170307312987, 0.10149188992415659, 0.0, 0.6610680803113426], [1.0, 0.9424955705158837, 0.3460671101020956, 0.5586287965980011, 0.2138858320364772, 0.27659002248832154, 0.22811482944177705, 0.8166923469675957, 1.0, 0.02195653215805154, 0.4415621746337805, 0.35155908997208113, 0.8076638242407269, 0.7266179935241239, 1.0, 1.0, 0.24253249303486552, 0.5438994807428162, 0.04961302362819436, 1.0, 1.0, 0.8024470260970323, 0.733322060848138, 0.6959358102795684, 0.6050159812977507, 0.8438000425113789, 0.2737964376276834, 0.8913609763031399, 0.55091215953178, 0.3102201520550131, 0.3253833753919191, 0.7058647578114671, 0.4101765063581174, 0.1382376321633808, 0.34111278628934155, 0.9990825294447601, 0.51533034986603, 0.24950412141659167, 0.8528272976774035, 1.0, 0.42605427416928704, 1.0, 0.22838281329680746, 0.09459661286858617, 0.20938422876987806, 0.0, 0.41547271296591626, 0.4567014121520503, 1.0, 0.762564817676273, 0.8669450356610927, 0.35192239262979436, 0.3880301743024219, 0.2436400317008846, 0.8591365624421672, 0.31519788362369966, 0.4185066784737672, 0.526296227811121, 0.5729012059037546, 1.0], [1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.8970666866060996, 0.4705276927683328, 0.4731389825472717, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.5430786857644936, 1.0, 0.0, 1.0, 0.27075919894493805, 0.0, 1.0, 0.26860590610473317, 1.0, 0.0, 1.0, 0.8267233649514347, 1.0, 0.0, 1.0, 0.30064127815557473, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.5057181518143694, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0], [0.22205202635511678, 0.6552321416367798, 0.6577737881957927, 0.41772941849654904, 0.35864669439361907, 0.9470563925472726, 0.3018563384572629, 0.34773913373899806, 0.48623434450943076, 0.9157037500340264, 0.10442296251684488, 1.0, 1.0, 0.4534880779396026, 0.7848991339224077, 1.0, 0.4944522839817176, 0.499089273084964, 1.0, 0.7224908664983675, 1.0, 0.7653405529473352, 0.5072201324400524, 0.9301006103673028, 0.6362967655648125, 0.6308627351500539, 0.0, 0.14279627306106935, 0.30565741166690324, 1.0, 0.6776946253750158, 0.0, 0.1902600114930298, 0.1884261824086488, 0.31260305485499085, 0.9058133289262182, 0.7216760376150292, 1.0, 0.0, 0.48059363319955445, 0.7876846632681771, 0.8658632414221359, 1.0, 0.9265859354346389, 0.2542477628091032, 0.9076052931169986, 0.3267929533181123, 0.09145757902073984, 1.0, 0.46974675401262195, 0.9298143234957065, 0.6502097736869841, 0.5319952398931113, 0.0, 0.9150835250365859, 0.6143792664204766, 0.630897178748892, 0.5179020327282242, 0.3235550849309657, 0.5695305891610528], [1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.021166079736724172, 0.6546687613337315, 0.028712775994176418, 0.759485191051838, 1.0, 0.508920337350507, 0.6640186637860516, 1.0, 1.0, 1.0, 0.572093707422851, 0.3002203284601004, 0.3928495319618646, 0.12188086043947499, 0.5795108654209935, 0.9032685445632423, 1.0, 0.05688194448752997, 0.711164919070234, 0.0663727738107178, 0.35437650352945144, 0.2963858659751128, 1.0, 0.5197829182536273, 0.866959594317089, 0.0, 0.4671219820869172, 1.0, 0.0, 0.07658323608954871, 0.7207487259434504, 0.0, 0.0, 0.654934496524083, 0.008315384529454205, 0.6419804975485751, 1.0, 0.8747079760465369, 0.026445495560702276, 0.2706955594475706, 1.0, 0.20309106639426142, 0.5395768458763988, 0.11999904958275798, 1.0, 1.0, 0.0, 0.18057846212266068, 0.6064262942896795, 0.0, 0.7439644790465597, 0.0, 0.32799812343280293], [0.1924590548979033, 0.3647052763584718, 0.23186630036387051, 0.35465978092588996, 0.5086435608626068, 0.0, 0.47061035921042155, 0.41920820619705895, 1.0, 0.5085560998249448, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.2879647772936509, 0.31180360164788723, 0.9214949001942949, 1.0, 0.4089306839798169, 0.48278141789152895, 1.0, 0.6814222357638784, 0.5576527175824226, 0.0, 1.0, 0.6159063444135982, 1.0, 0.6824864221158032, 0.0, 0.0, 0.0, 0.8465639428276355, 1.0, 1.0, 0.2748451791922231, 1.0, 0.0, 1.0, 1.0, 0.8337659046445286, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0, 0.53960796497635, 0.41325941164130164, 0.0, 0.2672104205400798, 1.0, 1.0, 0.9661548599098015, 0.1715422980877703, 1.0], [1.0, 0.5517900498727242, 0.20239291103148027, 0.5370628829249711, 0.7991183227930581, 0.0, 1.0, 0.1784555780064586, 1.0, 0.12325789210963894, 0.6201189962911783, 0.44151664889165587, 0.6740052139702847, 0.6082597249802882, 0.8538174494476448, 1.0, 0.3454361623478042, 0.5584925150952221, 0.2548017874256376, 0.43809566254546356, 1.0, 1.0, 1.0, 0.9533048478382006, 1.0, 0.7210308746101513, 0.5236186679671497, 1.0, 0.0, 0.6146530603008704, 1.0, 0.3420126908551523, 1.0, 0.17158502550464869, 0.0, 0.0, 0.3241210033427012, 0.17780914579904977, 1.0, 1.0, 0.10112541963071923, 0.4785454026370411, 1.0, 1.0, 1.0, 0.7340244872400868, 0.18869045560190953, 0.0, 1.0, 0.6552201056963955, 0.87247849605904, 0.0, 0.4349657231647012, 0.1607510272080959, 1.0, 1.0, 0.9447371807165513, 1.0, 0.2359258355973883, 0.0], [0.8706712590281991, 0.6211253793441066, 0.08896695531935096, 0.08592132999047035, 0.9030680661765279, 0.3990464584937704, 0.4755810789617437, 0.8119241584350038, 0.19113495615610748, 0.5967600139677414, 0.45510788922832807, 0.30940922498980605, 0.19526566319518363, 0.1404652277243545, 1.0, 1.0, 0.8976561787310151, 0.07904056988226897, 0.0, 0.4455798490260066, 1.0, 0.7819856575855924, 0.45231255285781163, 0.0, 0.9583303341936048, 0.7841764020789688, 0.5424443019257995, 0.6821034802679107, 1.0, 0.0, 1.0, 0.6403183596618519, 0.6061816353560773, 0.3521964763751379, 0.9062407854851812, 0.0752207624046006, 0.6727836906825824, 0.47137967256846613, 0.28797342643281154, 0.12380141019230576, 0.9495183771509182, 0.30748432813101795, 0.8207804852460779, 1.0, 1.0, 0.4856846660018626, 0.9863645025273656, 0.8394313944333421, 1.0, 0.7566489563091212, 0.7581182482653053, 1.0, 0.8019583693384206, 0.14982967632640198, 0.18862743847228597, 0.0, 1.0, 0.8879279481210008, 0.9786037922594159, 0.2625025010686328], [1.0, 0.740422281912238, 0.24181285854491663, 0.4993596793638767, 0.49450207803230684, 0.6533991510418228, 0.958106568028804, 0.956563790821651, 0.530903394987565, 0.16858092047193832, 0.8915836206285587, 0.26939498026268993, 0.7502513904791386, 0.9651215901203898, 0.6477105393275043, 1.0, 0.9952474971192085, 0.8472430785103812, 0.964121235245271, 0.5018854351420541, 1.0, 0.14366353682489477, 0.2673526384607836, 0.6389701780570067, 0.1282263129271101, 0.5504883789977603, 0.3309967529698951, 0.8275452445341173, 0.3810457024417208, 0.0, 0.656243263526432, 0.5306591212585952, 0.08379743260607417, 1.0, 0.846118835202177, 1.0, 0.0, 1.0, 0.905758521279495, 0.315386007557116, 0.0, 0.07486015974027554, 0.0, 1.0, 1.0, 1.0, 0.9314991724985799, 1.0, 1.0, 0.05271198101691988, 0.4795319751699734, 0.46294560304833354, 0.3908395037639637, 0.18813474093302562, 0.0, 0.04572198418885648, 1.0, 0.3052573744209236, 0.48982100080623625, 0.2820833603935313], [0.40939687179053064, 0.19984591844655397, 0.889632567207864, 1.0, 1.0, 0.5674793822345701, 0.0, 0.0, 0.4540635586591989, 0.0712084262272158, 0.0284486696909155, 1.0, 0.16433383991181885, 0.0, 0.0, 1.0, 0.0, 0.2663233282621482, 0.0, 0.5672958840336408, 0.29147783653599757, 1.0, 0.7356791376250456, 0.725000596344483, 1.0, 0.7844837636175996, 0.6168421455426191, 1.0, 0.16616763856297367, 0.0, 1.0, 1.0, 1.0, 0.9894239246214465, 1.0, 0.9222840671852763, 1.0, 1.0, 1.0, 0.0641810670180914, 0.3705574675559264, 0.29520186961297834, 0.6938826562904641, 1.0, 0.0, 1.0, 0.47238164445269276, 0.0, 1.0, 0.0010440417731954789, 0.23741888172365863, 1.0, 0.1094808251606893, 0.0, 1.0, 0.29466000038167806, 0.4956402118644605, 1.0, 0.6646220938168593, 1.0], [1.0, 0.05448701637553413, 0.160109056927332, 0.0, 0.8086396731624836, 0.0, 0.8090160642430839, 1.0, 0.8124483110211765, 0.5432518541433302, 0.049767064911584155, 0.8814064181242306, 0.0, 0.4184950880581369, 0.7200474594920326, 1.0, 1.0, 0.9201542774063064, 0.1109073858102725, 0.17361452006184178, 1.0, 0.46162374897231795, 0.24027094424493473, 0.6549099317145681, 1.0, 0.4159199882944544, 1.0, 0.07858497996998248, 0.9508923257670973, 0.5039100487299877, 1.0, 0.042199217399593786, 0.37063136114662937, 0.5121671902675919, 0.71082632481364, 0.6552895477159408, 1.0, 0.4353575574731281, 0.3204846062430921, 0.0, 0.2077833805978805, 0.27680286985964364, 0.12374498050841325, 0.6811162146937395, 0.893126721256198, 0.7248504721193241, 0.07240399981376594, 0.39411863163814015, 1.0, 1.0, 1.0, 0.8750959047406356, 1.0, 0.2205119986435816, 0.314202165114334, 0.0, 1.0, 0.8787610230621372, 0.8508789407324421, 0.6999796471122418], [0.789084816170946, 0.7976937236337897, 0.5346883088546784, 0.19553028007486867, 0.12424980294351724, 0.9066421236387746, 0.1574965929596035, 0.5333162308381758, 0.0, 1.0, 0.4481235346580197, 0.0, 1.0, 0.4644374725475392, 0.7795080629923465, 1.0, 0.7897458487596714, 0.0, 0.17586482963891528, 0.9154761968778812, 0.7653885051521415, 1.0, 0.5073809288819972, 0.0, 1.0, 0.5577498400903359, 0.5650973596498282, 0.8824551191918374, 0.930122374227152, 0.0, 0.914247479473614, 0.6267887348211497, 0.5945937926626835, 0.43821141361253824, 0.5358296570918621, 0.053115360267061096, 1.0, 0.7877975135120205, 0.39849167015585185, 0.41958165853351803, 1.0, 1.0, 0.4911975336311837, 1.0, 0.9421527416387864, 0.22406292734165734, 1.0, 1.0, 1.0, 1.0, 0.7078653231435466, 0.3789395856831974, 0.765878377986956, 0.2844960484007051, 0.2984803282010101, 0.4429174454308701, 0.24920588784210462, 0.416915224907934, 1.0, 0.0], [1.0, 0.0, 0.5324344625303746, 0.0, 1.0, 0.0, 0.8629451028255389, 0.5675182134258473, 0.0, 0.8802952485665552, 0.0, 1.0, 0.02293662130146544, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 0.21357431476990577, 1.0, 0.4213716082309157, 0.06718547788641463, 1.0, 0.18827872953579844, 1.0, 0.8852831645894867, 1.0, 0.0, 1.0, 1.0, 0.34367511221603214, 0.5030689574259274, 1.0, 0.0, 1.0, 0.0, 0.10716075640543987, 0.37201972806258604, 0.42085909324922227, 0.0, 1.0, 1.0, 1.0, 0.23664128452689187, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.6967500028642238, 0.0, 1.0, 0.0, 1.0, 0.4774990790451386, 0.6178115347900812, 0.0], [1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 0.4842370246899995, 1.0, 0.07453861273930695, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.6706432179807899, 1.0, 1.0, 1.0, 0.0, 1.0, 0.2748290214171537, 1.0, 1.0, 0.9711582867351161, 0.0], [1.0, 0.9229633752905969, 0.12808305561484382, 0.0, 0.7925833520240544, 0.3625425796599108, 0.1563720533372817, 0.4204797997007337, 0.42024056182548086, 0.22073578415498152, 0.4887281726559902, 0.5553060455400809, 0.585669322109889, 0.0, 1.0, 1.0, 0.5550103246031582, 0.7494344048434511, 0.1352201319294933, 1.0, 1.0, 0.5555005122388619, 0.6399136680704732, 0.49117894284849106, 1.0, 0.670657658747812, 0.737854902638037, 0.8211491813158578, 0.4275856380172235, 0.0, 0.9905214357433257, 0.375532650741469, 1.0, 0.01653863109210175, 0.6406037827145817, 0.2415169850510445, 0.21991794595026956, 0.13698019420530994, 0.11361574820862934, 0.5919179486859489, 0.6604643481721847, 0.3206698277395744, 1.0, 1.0, 0.1873207582088279, 0.6945680610802254, 0.5326380502301851, 0.6992815853661865, 1.0, 1.0, 0.2886010146128493, 0.9249852443022599, 0.0, 0.0, 0.5446614233808513, 0.18682400348733214, 1.0, 0.11115777347811467, 0.5979101795881657, 0.19901028107375063], [0.29000578907309177, 0.12920986513521204, 0.07014451378417935, 0.18283363916044254, 0.6135723287422497, 0.4677147613606759, 0.7820267258218165, 0.4933282297002539, 0.8431189371193508, 0.7422628353588462, 0.05656998407518063, 0.45264290838874277, 0.17589665780608899, 1.0, 0.08251258824855497, 1.0, 0.46346130126841256, 0.06197610844246469, 0.0, 0.6491352597130715, 0.35705986987281485, 0.00448446627454583, 0.18278902864352456, 0.21522443749815118, 0.3625843206448005, 0.716194703378123, 0.9481597706870688, 0.37294626447415175, 0.6947328050297319, 0.5810258427943928, 1.0, 0.7207539409690612, 0.9769530884697788, 0.837127333662699, 0.3954156215143872, 0.27981100061487263, 0.4112071165672557, 0.8346244029168425, 1.0, 0.23515778824039077, 0.19302437337531983, 1.0, 0.789190926625379, 0.0, 1.0, 1.0, 1.0, 0.486833080173384, 1.0, 0.2667491237242362, 1.0, 1.0, 0.4821544539954101, 0.0, 0.04094298926291728, 0.15246416963037723, 0.7280018670036343, 0.37020834685500986, 0.2535138820009586, 0.7813122319158115], [0.7957757210436075, 0.262871581770062, 0.6171957053047881, 0.16174710450018182, 0.7186663581360485, 0.6700094260344185, 0.7209830085976526, 0.33401745603126565, 0.706346955181909, 0.9362773182284195, 0.0, 0.666689492020891, 0.6357468154763726, 0.004196786796806212, 0.3512481013458552, 0.7890132610653116, 0.7600526938504241, 0.23869848504481617, 0.1425893420909402, 0.7772267042022823, 0.11572962604969486, 0.7693895195046404, 0.27908668156552, 0.29022665017754873, 1.0, 0.9261962852805867, 0.5275283274885381, 0.9065506084551143, 0.4947006881728696, 0.6563958234520234, 0.3243910210315851, 0.5176538396342156, 0.47995113591027333, 0.5761948733602735, 0.29462813726042786, 0.6435216086099702, 1.0, 0.2835965992102211, 0.0, 0.0, 0.5627074984953374, 0.21761692088100815, 0.731569484897029, 0.9092237287003276, 1.0, 1.0, 0.7284602438603164, 0.15848924295023892, 1.0, 0.7380420559907566, 0.5463549096594664, 1.0, 0.18010334695211333, 0.0, 0.24568057898515358, 0.30524024720128573, 0.997263644420398, 0.5440270026803594, 0.716803044454587, 0.09344149934613602], [1.0, 1.0, 1.0, 0.17196692078978945, 1.0, 1.0, 1.0, 1.0, 0.45768479565646264, 0.6451448185049581, 1.0, 1.0, 1.0, 0.0, 0.040246236603817306, 0.36581504469051207, 0.6129846406765268, 0.0, 0.6842036700678301, 0.42816403760369326, 1.0, 1.0, 0.8140952431971752, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 0.9622718258472435, 0.0, 1.0, 1.0, 0.273734052845267, 0.0, 0.0, 0.07829432169705561, 0.0, 0.47603784403364596, 0.6823606550313006, 0.006702780024093797, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.6648534878234442, 0.0, 1.0, 0.5936269382694291, 0.0, 1.0, 0.17491732080054218, 0.0], [0.40831100590667585, 0.6561820319859907, 0.384268996809023, 0.8275290338618185, 0.7791409576995019, 0.08498545455663425, 0.6058025679906299, 0.4130128104904008, 1.0, 0.0, 0.03119469346593605, 1.0, 0.04995139052316366, 0.9173416634260736, 0.5140052943188886, 0.6288579907982695, 0.11263235736923201, 0.9806758518566095, 0.0, 0.2752855961459972, 1.0, 0.1889765478159794, 0.4074836445775481, 0.7195901707549562, 1.0, 0.09940603846235463, 0.4630957132948695, 0.6188040708992179, 0.7569404394562095, 0.312860434914484, 0.0, 0.0, 0.16362232741156796, 0.46514568130463485, 0.24300115529255117, 0.4127210841707268, 0.11284061642555697, 0.8437873260995156, 0.23810835588211615, 0.10066432756080343, 0.0, 0.9445000334652696, 0.19248709902240746, 0.24317828187596582, 0.0, 1.0, 0.6146584324639507, 0.0, 1.0, 0.5785830751921655, 0.23472626526489804, 0.0128386321631737, 0.3662782175849848, 0.5324017282250935, 0.7944514285132418, 0.8116384861307461, 1.0, 0.40989831095677576, 0.5447086841103862, 0.5357826233950018], [0.8659689650159396, 0.29480997514932766, 1.0, 0.791308380628802, 0.4814231538146708, 0.31836545803848554, 0.628532839323037, 0.7059460505901421, 0.3950396948684256, 0.9994699142707582, 0.41750819430033714, 0.37876167616337636, 1.0, 0.6207350102617711, 0.6662475120768829, 0.6079899796543379, 0.9627969841852165, 0.23296398171161634, 0.1880254906039134, 0.17716820068106567, 0.23466794350300083, 0.6619449094606796, 0.7083914012596033, 0.36392299310513815, 1.0, 0.9043133866645859, 1.0, 0.3186501457872685, 0.6978856314118963, 0.5442411846764786, 1.0, 1.0, 0.2886819068218721, 0.9925297036371242, 0.7787614022207104, 1.0, 0.6204349197186015, 0.4949345434636425, 1.0, 1.0, 0.007107198080875413, 1.0, 0.627789714683098, 0.1453885001018303, 0.4619084689623027, 1.0, 0.35676288050227195, 0.8920241079124526, 1.0, 1.0, 1.0, 0.3870812211810288, 0.6973611898039488, 0.04144282111251065, 0.4808470822892194, 0.7662066946265611, 1.0, 0.03019098546876202, 0.43905379535748856, 0.6865704737728159], [0.35210410482219295, 0.4206718965611826, 0.43297309469549256, 0.8239081091641188, 0.9703822109682911, 0.4227853238205405, 1.0, 0.33335154727569766, 0.5427700751968197, 0.7800547860883912, 0.9156558962876623, 0.40859035609468947, 1.0, 0.8664542116974278, 0.0, 0.0, 0.013166872676008277, 0.13452786570615735, 0.9841651480340293, 0.6686444148405595, 0.384998455335962, 0.22926527802296248, 0.9548007614067933, 0.47907904993338757, 1.0, 1.0, 0.7147420728321793, 0.7182300294883949, 0.8503342271730069, 0.3530585420564367, 0.0, 1.0, 0.8947260806825867, 0.5777100964287153, 0.6300931095270865, 0.3168148437495414, 1.0, 0.12789233829896499, 1.0, 0.0, 0.0, 0.35143637181515525, 0.1557101845121267, 1.0, 0.5795558478361079, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.3182875081068959, 0.5623202598852207, 1.0, 0.398492425276693, 0.2872801065981781, 1.0, 0.7654506914014664, 0.5192358285702727, 0.2914122930093766], [0.6857338936932342, 0.5955121581361751, 0.721385681573571, 0.5420802220186552, 0.06538993010686818, 0.0, 0.021296684409857023, 0.5408992939041605, 0.08779884878940282, 0.7235950687233433, 0.46525318650644204, 0.21950282889864894, 1.0, 0.0, 0.8118608729984897, 0.25357026761086865, 0.7463523706231143, 0.0, 0.8017545978989301, 0.5608481400529901, 0.0, 1.0, 0.45495443863147594, 0.949016781153515, 1.0, 0.6298903734973842, 0.8058711736812323, 0.06358031764921891, 1.0, 1.0, 1.0, 1.0, 1.0, 0.7489894435378781, 0.5071605253567034, 0.4122117397183745, 0.8592368022571201, 0.5617321900110954, 1.0, 0.0, 0.46561579101152606, 0.46607358901688856, 0.8229123859409382, 0.0, 0.8371876704494385, 0.9729059436200808, 0.5396329230826844, 1.0, 1.0, 1.0, 0.16701275467971277, 0.6347528033995534, 0.9948419652588475, 1.0, 1.0, 0.48208149062391015, 1.0, 0.9998843506555222, 0.5048644825506873, 1.0], [1.0, 0.8207847164262263, 0.5106845436969427, 0.5960040223898622, 0.3417426950288242, 0.14341238605180434, 0.0, 1.0, 0.4483268389356254, 0.6180672257991664, 0.3012936035573566, 0.389728388129168, 1.0, 0.902411656223955, 0.18532398062049701, 0.2623303369563771, 1.0, 0.4754392881895424, 0.7016454147665075, 0.10644778528317063, 0.3656381640801833, 0.571205876943676, 0.8719694224659464, 0.3270103671061969, 1.0, 1.0, 1.0, 0.8118660165335337, 0.5828983987815235, 0.1726765161699452, 1.0, 0.5795760849213626, 0.9592004313652788, 0.44922419490031096, 1.0, 0.9354900160669645, 0.7762841867807148, 0.05795092331646818, 1.0, 0.49077553762132176, 0.0, 0.4390126551619638, 0.43424358299537713, 0.0, 0.13149072841144832, 0.8009068702786456, 0.9346676621253365, 0.8050134212883073, 1.0, 1.0, 1.0, 0.4960572762731625, 0.3531761238138028, 0.9127529616129277, 0.634911317572848, 0.7668640543149232, 1.0, 0.6991416864734605, 0.36351104678824553, 0.7571565813000019], [0.5951134747857251, 0.494495272683078, 1.0, 0.3028689835712309, 0.7363386241832474, 0.5435802020700603, 0.14931040746083585, 0.590001372598043, 0.5319676906655391, 0.8160741553774443, 0.7696548416250986, 0.6817789915118202, 1.0, 0.03759986559693621, 0.8281576299067566, 0.5529637987270126, 0.7319218009002315, 0.2630399048891497, 0.6739153377771895, 0.6817956990991911, 0.7428271018353614, 0.8957522185020256, 0.6649789122082325, 0.2847179643848445, 1.0, 1.0, 1.0, 0.4805272628620172, 0.6460577792088583, 0.5481066725713462, 1.0, 0.22373196690351282, 0.4940023929626427, 1.0, 0.955289771885957, 0.5121955953138915, 1.0, 0.0578502200290108, 0.8313990670589219, 0.8491355623135391, 0.0, 0.9021180355075571, 0.5802828981208847, 0.0, 0.46675470441369565, 0.15976105320594514, 0.0, 0.26807859257136235, 0.9263298541866718, 1.0, 1.0, 0.9868303536434528, 0.30628767453211864, 0.0, 0.04507683172661539, 0.19253251808456934, 0.45173093966447075, 0.6064000124764993, 1.0, 0.8660894133743305], [0.7442652711421478, 0.6099963855367828, 0.45846525016246875, 0.5575079878662451, 0.5322487036049773, 0.14964272966024267, 0.6608619759369718, 0.44613413087223086, 0.7008792147174923, 0.7634025896956367, 0.0, 1.0, 1.0, 0.36432978017466383, 0.4900872420479055, 1.0, 1.0, 0.260901112026385, 0.34851201723435127, 0.07827315689277915, 1.0, 0.7837431121950281, 1.0, 1.0, 1.0, 1.0, 1.0, 0.9809957089097905, 0.8243590555084741, 1.0, 1.0, 1.0, 0.20599889764273516, 0.7580907179587953, 0.5932987864154501, 1.0, 1.0, 0.36728431657873134, 0.5207497822804554, 1.0, 0.0, 0.9187606793420874, 1.0, 0.33660002475710715, 0.18620120348853098, 0.8701734844250405, 0.25275203878193053, 0.5870698634148848, 0.4982583281346208, 0.44126341889960247, 1.0, 0.0, 0.7028347422345288, 0.15287751713321335, 0.803925383415889, 0.9374032516846437, 1.0, 0.3189621237652678, 0.0, 1.0], [0.8430662424337958, 0.0632536234197394, 0.3385647135974677, 0.6142132124058499, 0.8682999589779151, 0.37791007796444587, 0.3406208021993941, 0.18546124950769163, 0.7671497500827906, 0.6753293009944674, 0.5556054229517831, 0.35452655100980374, 0.9806579924512738, 0.0959881335499804, 0.842299990651578, 0.6615613701934464, 0.8339721026446038, 0.006152005232901605, 0.32196056645035426, 0.3369236072057488, 0.5748336804582503, 0.955989374775841, 0.4977818455049652, 0.24963907517140632, 0.11582567527443124, 0.9090717500638245, 0.5659106671833739, 0.9585107177783183, 0.25962838789139003, 0.14143354200436578, 0.24522448084910659, 0.9603889576522746, 0.34546798475990464, 0.9786218587057344, 0.8136455236533986, 0.5766415407382623, 0.6461849354239143, 0.21051132362963337, 0.8381824379086865, 0.3255333364463215, 0.3208783249816471, 0.30944801847629405, 0.8215806973160936, 0.13493112012679512, 0.1133815699951787, 0.43994217101479227, 0.5261588061022335, 0.4984715525800718, 0.5701267832309405, 0.34146167216170126, 0.7519152373640857, 0.41579263072492334, 0.494644183669228, 0.16806778573022343, 0.4610588455822814, 0.7954926691661864, 0.3030451723273296, 0.48750307226695166, 0.24464037841669334, 0.4616955406707347], [1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 0.9334961853167166, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.9167036271629667, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0], [0.4190549184256247, 0.36704081567285335, 0.25124186553724487, 0.0318736026209876, 0.5180665914940553, 0.07908229229342913, 0.3657902626529744, 0.3827971461485862, 0.0071983826396943024, 0.7233349526919669, 0.41655534254642346, 0.112971016002296, 0.0009466038896308595, 0.9133964142473064, 0.8535807409730263, 0.726200870466985, 0.8171100998199812, 0.761274408145673, 0.02065915435633581, 0.6544761632313604, 0.4196031196216786, 0.6635736788858719, 0.8054467372050255, 0.7567416196654152, 0.9559272016612257, 0.987942093529779, 0.8234995608398029, 0.9550421257993507, 0.8437067688488231, 0.6918623994751647, 0.8497787339179443, 0.2899705290448426, 0.16697868242068173, 0.8263987717706059, 0.649849539193041, 0.9538904372884847, 0.744802966545863, 0.9854805018230495, 0.08281628361306227, 0.5516043448992728, 0.30148469201213607, 0.8194075205915328, 0.2772317462044263, 0.7450466770078937, 0.6304517502352838, 0.3437048190061304, 0.831225023505759, 0.01713434873176656, 0.316071167211807, 0.39424274459294384, 0.8029920879553104, 0.5246824887722978, 0.8198765446373926, 0.14745242026297614, 0.45446617466817385, 0.9182311232373425, 0.35674827522981517, 0.8253194003303517, 0.6265798054463718, 0.09196932886717547], [0.0967382802528425, 0.08895845993437747, 0.5772720370099664, 0.8536414685700803, 0.6536891826190169, 0.5961120542383673, 0.30533270526279416, 0.7354256071395261, 0.6922508820436344, 0.46427643014819264, 0.5815261301676192, 0.7097308842627935, 0.8938050761555726, 0.7975277489122704, 0.04195824115269187, 0.6707608791539565, 0.8265345595145083, 0.33230472753426293, 0.6982022739640327, 0.7825939705572751, 0.6481587888370913, 5.967616993751702e-05, 0.9663656667739847, 0.21815927638322136, 0.6533355025212993, 0.8534645324101471, 0.01370437745420228, 0.9965969497175222, 0.9243009809449155, 0.3962489701699632, 0.8212635285249797, 0.4385461260445802, 0.25069484029122874, 0.9927523241190412, 0.8972577635640048, 0.02017041027597966, 0.9309254394563933, 0.9184849658068821, 0.12655951755077557, 0.8873896054175548, 0.04620972225551257, 0.8899497201794792, 0.14351983849920028, 0.8260278662811507, 0.34993986807254623, 0.9932309213485858, 0.4591907842038703, 0.435825141824684, 0.0607099588349075, 0.18767893694031118, 0.8987750412976728, 0.686884754052743, 0.21221374841078972, 0.25097153297068825, 0.9542242485159508, 0.23346562524183617, 0.6955486794489074, 0.7209504066009927, 0.9068558730757369, 0.050953533859450464], [0.9461654277670586, 0.8490447284260888, 0.9883320910786187, 0.7730858773414434, 0.23922171810100262, 0.45515173927939745, 0.8982963797287048, 0.9552449713662295, 0.9419817474800669, 0.8455028566027385, 0.08227809977719737, 0.7014882244652582, 0.43569115625078836, 0.5212104476151863, 0.9210250596903476, 0.033166319274901664, 0.2793004455042631, 0.3066271616104092, 0.3268546020442245, 0.9929750006521649, 0.06329819695096918, 0.4536407671640774, 0.5978086269043646, 0.22244306138661202, 0.8716283124286371, 0.9894661884602584, 0.6723211960087253, 0.29233869574533927, 0.24332681003592455, 0.8974340849705571, 0.5115939003763557, 0.32123569614437947, 0.538358704562306, 0.556360274799645, 0.9564052072563487, 0.11049003214123701, 0.7243028657901827, 0.23940917761855723, 0.9255514895795731, 0.49774690791505016, 0.5015068609879115, 0.5044704390856172, 0.8973460296044367, 0.703304482957468, 0.7582956543911519, 0.7757346022069832, 0.04450565776479632, 0.26422253501285525, 0.02003705739487172, 0.7352948015908048, 0.9989492175000311, 0.4133344679845944, 0.41324255401322796, 0.7506984740671067, 0.7775046935297497, 0.8129907898032248, 0.8579282119587908, 0.8446546090972008, 0.6345237382648317, 0.9661093266420687], [0.27662956185006043, 0.136528345270464, 0.8785661821392733, 0.32836384977808714, 0.22077965514282855, 0.8156415888718733, 0.10109497851163854, 0.9721083785754018, 0.6650300825399752, 0.710928422243321, 0.4228554111470266, 0.8068092753136107, 0.8918412224801949, 0.31998206366616094, 0.7750149324880626, 0.37820325600184534, 0.6874381287216732, 0.07943028746679816, 0.1004655489681027, 0.6445454908369291, 0.45447134133611955, 0.3850557942615984, 0.7465977657713574, 0.1948311301134507, 0.808976993309935, 0.6307890022062502, 0.6191526150260842, 0.33637720495788054, 0.5740886902776376, 0.4261559198848387, 0.9268612784767042, 0.6177968989988376, 0.18252729869068754, 0.15949427069301228, 0.9831841211601168, 0.5864628273452509, 0.7621698504403539, 0.011165489483916826, 0.6151085463419635, 0.5892520862370175, 0.8281820921713996, 0.35521074427002425, 0.8973840551883763, 0.981847394337625, 0.4700622937576966, 0.9149838539676912, 0.8735465168965225, 0.5908244115676339, 0.22211027585576765, 0.13559589058829094, 0.9136106851684104, 0.35333175336544437, 0.39472271450451935, 0.07521107098149839, 0.927836812007577, 0.22196524856214678, 0.5757071530132513, 0.4647298228126837, 0.9014044818707234, 0.4724842668858007], [0.9387938264918072, 0.8882625945548385, 0.9255390038922295, 0.5029535918424464, 0.6160081951609988, 0.8097618431254132, 0.9054470400642242, 0.9850198944758998, 0.5308443066780273, 0.22169071597237638, 0.7743336896755905, 0.579570089052524, 0.27879501185397976, 0.002732650114197322, 0.5694341409074132, 0.45779654635537603, 0.05857407510047609, 0.9762373866957539, 0.6466175077930986, 0.9019405667280814, 0.2907203832193073, 0.6344011196535092, 0.1757955594747738, 0.0727149794953711, 0.2546697016087313, 0.5264168366313928, 0.7787726400805443, 0.0636377919044885, 0.27270924605826, 0.47465684166087796, 0.04310219655876358, 0.8605152510644518, 0.7902326484153379, 0.5228115517346557, 0.930959053568104, 0.002956267309341843, 0.07000860138666067, 0.3667255036658344, 0.6524016094579848, 0.9570144589587752, 0.1505964625372627, 0.9871537315014882, 0.8980304332505764, 0.015478964112294217, 0.32308115201255744, 0.5300792668355201, 0.7540378938909825, 0.36385581868113376, 0.6634170546174608, 0.3058785334826318, 0.9744064331027078, 0.43072111355262654, 0.4672447899023603, 0.34582949506784083, 0.09684747184572831, 0.48964771698072407, 0.940696471755135, 0.5203933449277385, 0.7221230331526565, 0.19842906064658067], [0.9106002244643386, 0.9667999551521544, 0.3404185441539947, 0.8096647082667533, 0.5404277741246474, 0.7840482573038112, 0.02011786764886581, 0.10559958474620004, 0.9533330879737307, 0.6127945201712147, 0.039925098214745554, 0.06849568102960148, 0.9988371969883568, 0.4457241733585756, 0.5042268567253467, 0.2826327677112414, 0.5850770793697526, 0.4297752939766015, 0.6024262070877476, 0.6508143795367556, 0.44004051555076906, 0.47876360252605155, 0.9393048395686673, 0.6443157844814991, 0.937056806704604, 0.14959259486115287, 0.024929162785580224, 0.9772065155118946, 0.7341333251631007, 0.14690165055149743, 0.07699485227836401, 0.4305449940633995, 0.7350757885147622, 0.8407275940696586, 0.7995352607762737, 0.7406622378255011, 0.009106946641956106, 0.7344886305341309, 0.42233016207713303, 0.03707268099723194, 0.114080125645066, 0.13686674894080866, 0.1361641059911262, 0.1647568368960464, 0.9918494479517047, 0.36502431607783875, 0.25626246578928885, 0.45739515959495525, 0.9765012281233361, 0.21972441431533513, 0.9262530513528155, 0.23524091300720645, 0.03599875427088118, 0.050739581090987765, 0.7597563739449168, 0.8282662670849864, 0.9518327718373896, 0.22921964976151782, 0.9742931556421534, 0.8782311013501107], [0.8412253841050844, 0.5387997360306974, 0.9376622743988675, 0.9605480392499521, 0.1755791881334762, 0.21978514116411269, 0.365487416266115, 0.5684627646485104, 0.6709639805229071, 0.8105146233849746, 0.223065959768807, 0.13844894565176927, 0.9626447665834427, 0.814952086076234, 0.7236630459417206, 0.26189059722287206, 0.8410136664387802, 0.645037928752759, 0.2099428430605395, 0.5708215582666888, 0.5589748260558962, 0.9551163823675842, 0.9925201557128874, 0.7167657148779265, 0.38822620525886087, 0.935799633345581, 0.17420039641661214, 0.5800185508502845, 0.05271055480679589, 0.5268664269975054, 0.982463818338826, 0.622083739787335, 0.0973719675295677, 0.718632597968769, 0.4234492588773282, 0.25628738265566714, 0.5245467032265493, 0.8098504157234223, 0.38272299347787286, 0.9339655912944935, 0.8790766758336537, 0.21486830422653896, 0.8320847912519495, 0.8908164278349916, 0.014749775755836584, 0.9686497280029222, 0.8121467266092998, 0.5881168757435881, 0.8730913656463767, 0.42846560417923474, 0.1567332015810178, 0.9063637734893294, 0.9949201348209961, 0.8320446854803618, 0.6215854351960919, 0.7570616233906627, 0.9025267976789777, 0.9914605629666785, 0.9380426461969864, 0.8101609772435437], [1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.9049191632486583, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0], [0.5350125988885319, 0.013634688529458375, 0.674299288642751, 0.8226881120878542, 0.23139542874349778, 0.7808504943582875, 0.023169178294767948, 0.12415282669793429, 0.6464575212102878, 0.819075043432856, 0.3715880521577137, 0.4528786817689039, 0.9486001880697664, 0.489372877294442, 0.8739070388491307, 0.016086825020520838, 0.013166639886664225, 0.3978539780603385, 0.9814076633924014, 0.39429313251502185, 0.6100780088511903, 0.8239962000190405, 0.7714350303993172, 0.015189745486413723, 0.4506150783347963, 0.016153971638763424, 0.20810670667043957, 0.8356828929768515, 0.4457181038018885, 0.2379948583713874, 0.7853246107798715, 0.44620318272448456, 0.0391263674618414, 0.5973854327429781, 0.9317152128491936, 0.01688810614960035, 0.9547666437340241, 0.2294259449232368, 0.47848392697063613, 0.6786757791949488, 0.31796714089814665, 0.7355268768447615, 0.5870812738715624, 0.7651900216968003, 0.2534177542033285, 0.9718166030933117, 0.3763730042344756, 0.6667392440496215, 0.4068873326933572, 0.7266943356017765, 0.8553426098428485, 0.921766556642214, 0.8459294063587465, 0.8639641618610735, 0.18270178860882894, 0.1770208179111892, 0.6706258485877328, 0.6525056184769363, 0.5836860628032156, 0.8977954106969971]]\n",
       "       models: [GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606), GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5) + WhiteKernel(noise_level=1),\n",
       "                                        n_restarts_optimizer=2, noise='gaussian',\n",
       "                                        normalize_y=True, random_state=1291256606)]\n",
       "        space: Space([Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      ...,\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                      Real(low=0, high=1, prior='uniform', transform='normalize')])\n",
       " random_state: RandomState(MT19937)\n",
       "        specs:     args:                    func: <function objective at 0x76a00e711630>\n",
       "                                      dimensions: Space([Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         ...,\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize'),\n",
       "                                                         Real(low=0, high=1, prior='uniform', transform='normalize')])\n",
       "                                  base_estimator: GaussianProcessRegressor(kernel=1**2 * Matern(length_scale=[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], nu=2.5),\n",
       "                                                                           n_restarts_optimizer=2, noise='gaussian',\n",
       "                                                                           normalize_y=True, random_state=1291256606)\n",
       "                                         n_calls: 50\n",
       "                                 n_random_starts: None\n",
       "                                n_initial_points: 10\n",
       "                         initial_point_generator: random\n",
       "                                        acq_func: EI\n",
       "                                   acq_optimizer: auto\n",
       "                                              x0: None\n",
       "                                              y0: None\n",
       "                                    random_state: RandomState(MT19937)\n",
       "                                         verbose: True\n",
       "                                        callback: None\n",
       "                                        n_points: 10000\n",
       "                            n_restarts_optimizer: 5\n",
       "                                              xi: 0.01\n",
       "                                           kappa: 1.96\n",
       "                                          n_jobs: 1\n",
       "                                model_queue_size: None\n",
       "                                space_constraint: None\n",
       "               function: base_minimize"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Special tokens have been added in the vocabulary, make sure the associated word embeddings are fine-tuned or trained.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4cb3f45d9dc944bfa5ad159f7a7181c3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading checkpoint shards:   0%|          | 0/2 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:Loading model microsoft/Phi-3-mini-4k-instruct requires setting trust_remote_code=True\n",
      "WARNING:root:Loading model microsoft/Phi-3-mini-4k-instruct state dict requires setting trust_remote_code=True\n",
      "Special tokens have been added in the vocabulary, make sure the associated word embeddings are fine-tuned or trained.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded pretrained model microsoft/Phi-3-mini-4k-instruct into HookedTransformer\n",
      "Moving model to device:  cuda\n"
     ]
    }
   ],
   "source": [
    "from transformer_lens import HookedTransformer, HookedTransformerConfig, FactoredMatrix, ActivationCache\n",
    "from transformers import AutoModelForCausalLM, AutoConfig, AutoTokenizer\n",
    "import numpy as np\n",
    "from skopt import gp_minimize\n",
    "from skopt.space import Real\n",
    "import torch\n",
    "import transformer_lens.utils as utils\n",
    "from functools import partial\n",
    "import torch\n",
    "from botorch.models import SingleTaskGP\n",
    "# from botorch.fit import fit_gpytorch_model\n",
    "from botorch.optim import optimize_acqf\n",
    "from botorch.acquisition import ExpectedImprovement, LogExpectedImprovement, qLogExpectedImprovement\n",
    "from botorch.utils.sampling import draw_sobol_samples\n",
    "from gpytorch.mlls import ExactMarginalLogLikelihood\n",
    "import torch\n",
    "from botorch.models import SingleTaskGP\n",
    "from botorch.models.transforms import Normalize, Standardize\n",
    "from botorch.fit import fit_gpytorch_mll\n",
    "from gpytorch.mlls import ExactMarginalLogLikelihood\n",
    "# %%\n",
    "def loadTransformerLensModel(modelPath):\n",
    "    tokenizer = AutoTokenizer.from_pretrained(modelPath)\n",
    "    hf_model = AutoModelForCausalLM.from_pretrained(modelPath, low_cpu_mem_usage=True)\n",
    "    model = HookedTransformer.from_pretrained(modelPath, hf_model=hf_model, device='cpu', fold_ln=False, center_writing_weights=False, center_unembed=False, tokenizer=tokenizer)\n",
    "\n",
    "    return model, tokenizer\n",
    "\n",
    "# %%\n",
    "# MODEL_PATH = 'meta-llama/Meta-Llama-3-8B'\n",
    "MODEL_PATH = 'microsoft/Phi-3-mini-4k-instruct'\n",
    "# meta-llama/Llama-2-7b-hf\n",
    "# meta-llama/Meta-Llama-3-8B-Instruct\n",
    "model, tokenizer = loadTransformerLensModel(MODEL_PATH)\n",
    "dtype = torch.float64\n",
    "\n",
    "# %%\n",
    "device = 'cuda' #cuda\n",
    "model = model.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from transformers import AutoModelForCausalLM, AutoConfig, AutoTokenizer\n",
    "tokenizer = AutoTokenizer.from_pretrained('mistralai/Mistral-7B-Instruct-v0.1')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "datasetName = \"winowhy\"\n",
    "import json\n",
    "with open(f'bigbench/{datasetName}/combined.jsonl', 'r') as f:\n",
    "    train = [json.loads(line) for line in f]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Num tokens: 12\n",
      "hook_embed torch.Size([1, 12, 3072])\n",
      "blocks.0.hook_resid_pre torch.Size([1, 12, 3072])\n",
      "blocks.0.ln1.hook_scale torch.Size([1, 12, 1])\n",
      "blocks.0.ln1.hook_normalized torch.Size([1, 12, 3072])\n",
      "blocks.0.ln1.hook_scale torch.Size([1, 12, 1])\n",
      "blocks.0.ln1.hook_normalized torch.Size([1, 12, 3072])\n",
      "blocks.0.ln1.hook_scale torch.Size([1, 12, 1])\n",
      "blocks.0.ln1.hook_normalized torch.Size([1, 12, 3072])\n",
      "blocks.0.attn.hook_q torch.Size([1, 12, 32, 96])\n",
      "blocks.0.attn.hook_k torch.Size([1, 12, 32, 96])\n",
      "blocks.0.attn.hook_v torch.Size([1, 12, 32, 96])\n",
      "blocks.0.attn.hook_rot_q torch.Size([1, 12, 32, 96])\n",
      "blocks.0.attn.hook_rot_k torch.Size([1, 12, 32, 96])\n",
      "blocks.0.attn.hook_attn_scores torch.Size([1, 32, 12, 12])\n",
      "blocks.0.attn.hook_pattern torch.Size([1, 32, 12, 12])\n",
      "blocks.0.attn.hook_z torch.Size([1, 12, 32, 96])\n",
      "blocks.0.hook_attn_out torch.Size([1, 12, 3072])\n",
      "blocks.0.hook_resid_mid torch.Size([1, 12, 3072])\n",
      "blocks.0.ln2.hook_scale torch.Size([1, 12, 1])\n",
      "blocks.0.ln2.hook_normalized torch.Size([1, 12, 3072])\n",
      "blocks.0.mlp.hook_pre torch.Size([1, 12, 8192])\n",
      "blocks.0.mlp.hook_pre_linear torch.Size([1, 12, 8192])\n",
      "blocks.0.mlp.hook_post torch.Size([1, 12, 8192])\n",
      "blocks.0.hook_mlp_out torch.Size([1, 12, 3072])\n",
      "blocks.0.hook_resid_post torch.Size([1, 12, 3072])\n",
      "ln_final.hook_scale torch.Size([1, 12, 1])\n",
      "ln_final.hook_normalized torch.Size([1, 12, 3072])\n"
     ]
    }
   ],
   "source": [
    "# model, tokenizer = loadTransformerLensModel(MODEL_PATH)\n",
    "\n",
    "test_prompt = \"The quick brown fox jumped over the lazy dog\"\n",
    "print(\"Num tokens:\", len(model.to_tokens(test_prompt)[0]))\n",
    "\n",
    "hook_z_weight = 0\n",
    "mlp_out_weight = 0\n",
    "H = 0\n",
    "def print_name_shape_hook_function(activation, hook):\n",
    "    if(\"attn.hook_z\" in hook.name):\n",
    "        global hook_z_weight\n",
    "        hook_z_weight = activation.shape[-1]\n",
    "        global H\n",
    "        H = activation.shape[2]\n",
    "    if(\"hook_mlp_out\" in hook.name):\n",
    "        global mlp_out_weight\n",
    "        mlp_out_weight = activation.shape[-1]\n",
    "    print(hook.name, activation.shape)\n",
    "\n",
    "not_in_late_block_filter = lambda name: name.startswith(\"blocks.0.\") or not name.startswith(\"blocks\")\n",
    "\n",
    "model.run_with_hooks(\n",
    "    test_prompt,\n",
    "    return_type=None,\n",
    "    fwd_hooks=[(not_in_late_block_filter, print_name_shape_hook_function)],\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "32"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "H"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import random\n",
    "# random.shuffle(train)\n",
    "# with open(f'bigbench/{datasetName}/train.jsonl', 'w') as f:\n",
    "#     for item in train:\n",
    "#         f.write(json.dumps(item))\n",
    "#         f.write('\\n')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'idx': 2180,\n",
       " 'inputs': \"Please answer the following questions about which words certain pronouns refer to.\\n\\nBeth didn't get angry with Sally, who had cut her off, because she stopped and counted to ten. The 'she' refers to beth because SALLY TO REFER BETH.\\nThe above reasoning is\",\n",
       " 'targets': ['incorrect'],\n",
       " 'multiple_choice_targets': ['correct', 'incorrect'],\n",
       " 'multiple_choice_scores': [0, 1]}"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train[23]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[512, 15728]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "'correct'"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(tokenizer.encode('Incorrect', add_special_tokens=False))\n",
    "tokenizer.decode([15728])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'idx': 575,\n",
       " 'inputs': 'Q: What is the color most closely matching this HEX representation: #0fe627 ?\\n  choice: white\\n  choice: blue\\n  choice: orange\\n  choice: black\\n  choice: red\\n  choice: brown\\n  choice: yellow\\n  choice: green\\n  choice: gray\\n  choice: purple\\nA:',\n",
       " 'targets': ['green'],\n",
       " 'multiple_choice_targets': ['black',\n",
       "  'blue',\n",
       "  'brown',\n",
       "  'gray',\n",
       "  'green',\n",
       "  'orange',\n",
       "  'purple',\n",
       "  'red',\n",
       "  'white',\n",
       "  'yellow'],\n",
       " 'multiple_choice_scores': [0, 0, 0, 0, 1, 0, 0, 0, 0, 0]}"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\"idx\": 575, \"inputs\": \"Q: What is the color most closely matching this HEX representation: #0fe627 ?\\n  choice: white\\n  choice: blue\\n  choice: orange\\n  choice: black\\n  choice: red\\n  choice: brown\\n  choice: yellow\\n  choice: green\\n  choice: gray\\n  choice: purple\\nA:\", \"targets\": [\"green\"], \"multiple_choice_targets\": [\"black\", \"blue\", \"brown\", \"gray\", \"green\", \"orange\", \"purple\", \"red\", \"white\", \"yellow\"], \"multiple_choice_scores\": [0, 0, 0, 0, 1, 0, 0, 0, 0, 0]}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [],
   "source": [
    "message = [\n",
    "            {'role': 'system',\n",
    "  'content': 'Only Output \"True\" if you return to the starting point, \"False\" otherwise.'},\n",
    " {'role': 'user',\n",
    "  'content': 'If you follow these instructions, do you return to the starting point?\\nQ: Always face forward. Take 2 steps backward. Take 2 steps forward. Take 2 steps forward. Take 2 steps backward.\\nA:'}\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Utils.templates import *\n",
    "message = getMessageTemplate(datasetName)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[{'role': 'system',\n",
       "  'content': 'Only Output \"True\" if you return to the starting point, \"False\" otherwise.'},\n",
       " {'role': 'user',\n",
       "  'content': 'If you follow these instructions, do you return to the starting point?\\nQ: Always face forward. Take 2 steps backward. Take 2 steps forward. Take 2 steps forward. Take 2 steps backward.\\nA:'}]"
      ]
     },
     "execution_count": 122,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "message"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'<|begin_of_text|><|start_header_id|>system<|end_header_id|>\\n\\nOnly Output \"True\" if you return to the starting point, \"False\" otherwise.<|eot_id|><|start_header_id|>user<|end_header_id|>\\n\\nIf you follow these instructions, do you return to the starting point?\\nQ: Always face forward. Take 2 steps backward. Take 2 steps forward. Take 2 steps forward. Take 2 steps backward.\\nA:<|eot_id|><|start_header_id|>assistant<|end_header_id|>\\n\\n'"
      ]
     },
     "execution_count": 123,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.apply_chat_template(message, tokenize=False, add_generation_prompt=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[41568]"
      ]
     },
     "execution_count": 124,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.encode('Incorrect', add_special_tokens=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1000"
      ]
     },
     "execution_count": 125,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "metadata": {},
   "outputs": [],
   "source": [
    "prompts = []\n",
    "labels = []\n",
    "for i in range(len(train)):\n",
    "    if(len(tokenizer.encode(train[i]['targets'][0], return_tensors='pt', add_special_tokens=False)[0]) != 1):\n",
    "        # print(train[i]['targets'])\n",
    "        continue\n",
    "    message[-1]['content'] = train[i]['inputs'][:-3]\n",
    "    prompts.append({\n",
    "        'message': message,\n",
    "        'combined': tokenizer.apply_chat_template(message, tokenize=False, add_generation_prompt=True),\n",
    "        'TEMPLATE': \"{}\",\n",
    "        'prompt': train[i]['inputs'][:-3]\n",
    "    })\n",
    "    labels.append({'complete': train[i]['targets'][0], 'short': train[i]['targets'][0]})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1000\n"
     ]
    }
   ],
   "source": [
    "print(len(prompts))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<|begin_of_text|><|start_header_id|>system<|end_header_id|>\n",
      "\n",
      "Only Output \"True\" if you return to the starting point, \"False\" otherwise.<|eot_id|><|start_header_id|>user<|end_header_id|>\n",
      "\n",
      "If you follow these instructions, do you return to the starting point?\n",
      "Q: Always face forward. Take 7 steps left. Take 2 steps backward. Take 7 steps backward. Take 7 steps backward. Take 3 steps forward.<|eot_id|><|start_header_id|>assistant<|end_header_id|>\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(prompts[0]['combined'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "metadata": {},
   "outputs": [],
   "source": [
    "# input = [d['inputs'] for d in train]\n",
    "# output = [d['targets'][0] for d in train]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [],
   "source": [
    "# tokenizer.decode([29953])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "metadata": {},
   "outputs": [],
   "source": [
    "def runDefaultModel(model, tokenizer, prompt):\n",
    "    # print(prompt)\n",
    "    input_id = tokenizer.encode(prompt, return_tensors='pt').to(device)\n",
    "    model.reset_hooks()\n",
    "    output = model(input_id)\n",
    "    predicted_token = torch.argmax(output[:, -1, :], dim=1)[0]\n",
    "    # breakpoint()\n",
    "    return str(tokenizer.decode(predicted_token, skip_special_tokens=True)), predicted_token.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 132,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'True', 'short': 'True'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'True', 'short': 'True'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'True', 'short': 'True'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'True', 'short': 'True'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'True', 'short': 'True'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'True', 'short': 'True'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n",
      "Let {'complete': 'False', 'short': 'False'}\n"
     ]
    }
   ],
   "source": [
    "accuracy = 0\n",
    "count = 0\n",
    "for i in range(len(prompts)):\n",
    "    output, token = runDefaultModel(model, tokenizer, prompts[i]['combined'])\n",
    "    if(output == labels[i]['short']):\n",
    "        accuracy += 1\n",
    "    print(output, labels[i])\n",
    "    if(i == 20):\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [],
   "source": [
    "prompt = \"Instructions: For the given question, answer in only 'yes' or 'no'.\\nQuestion: Ka lies. Andree says Ka tells the truth. Audrie says Andree lies. Antwan says Audrie tells the truth. Millie says Antwan tells the truth. Does Millie tell the truth?\\nAnswer:\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "metadata": {},
   "outputs": [],
   "source": [
    "def runDefaultModel(model, tokenizer, prompt):\n",
    "    # print(prompt)\n",
    "    input_id = tokenizer.encode(prompt, return_tensors='pt').to(device)\n",
    "    model.reset_hooks()\n",
    "    output = model(input_id)\n",
    "    predicted_token = torch.argmax(output[:, -1, :], dim=1)[0]\n",
    "    # breakpoint()\n",
    "    return str(tokenizer.decode(predicted_token, skip_special_tokens=True)), predicted_token.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "answer, token = runDefaultModel(model, tokenizer, prompt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "120af80793da47c4b3b8ff87ca44737d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "input_id = tokenizer.encode(prompt, return_tensors='pt').to(device)\n",
    "outpout_token = model.generate(input_id, do_sample=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"Instructions: For the given question, answer in only 'yes' or 'no'.\\nQuestion: Ka lies. Andree says Ka tells the truth. Audrie says Andree lies. Antwan says Audrie tells the truth. Millie says Antwan tells the truth. Does Millie tell the truth?\\nAnswer: Yes, Millie tells the truth.\""
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.decode(outpout_token[0], skip_special_tokens=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "' Yes'"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "answer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Repo card metadata block was not found. Setting CardData to empty.\n"
     ]
    }
   ],
   "source": [
    "from datasets import load_dataset\n",
    "datasetName = \"object_counting\"\n",
    "ds = load_dataset(\"lighteval/big_bench_hard\", datasetName, trust_remote_code=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "json_list = [x for x in ds['train']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import json\n",
    "# import os\n",
    "# os.makedirs(f\"dataset/{datasetName}\", exist_ok=True)\n",
    "# with open(f\"dataset/{datasetName}/train.json\", \"w\") as f:\n",
    "#     json.dump(json_list, f)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "datasetName = \"winowhy\"\n",
    "import json\n",
    "with open(f'bigbench/{datasetName}/train.jsonl', 'r') as f:\n",
    "    train = [json.loads(line) for line in f]\n",
    "import json\n",
    "with open(f'bigbench/{datasetName}/validation.jsonl', 'r') as f:\n",
    "    val = [json.loads(line) for line in f]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "combined = train + val\n",
    "import random\n",
    "random.shuffle(combined)\n",
    "with open(f'bigbench/{datasetName}/combined.jsonl', 'w') as f:\n",
    "    for item in combined:\n",
    "        f.write(json.dumps(item) + \"\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2862"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(combined)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "# input = [x['inputs'].replace('(a)', '(a)').replace('(b)', '(b)') for x in train]\n",
    "# output = [x['targets'][0].replace('(a)', 'a').replace('(b)', 'b') for x in train]\n",
    "input = [x['inputs'] for x in train]\n",
    "output = [x['targets'][0] for x in train]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'Yes',\n",
       " 'No',\n",
       " 'No',\n",
       " 'No']"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "nShot = 1\n",
    "TEMPLATE = \"\"\"\"\"\"\n",
    "for i in range(nShot):\n",
    "    TEMPLATE += f\"{input[i]} {output[i]}\\n\\n\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Utils.templates import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "WEB_OF_LIES_FEW_SHOTS = \"\"\"Task: Evaluate the truth value of a random Boolean function expressed as a natural-language word problem.\\nInstruction: For the given question, answer in only 'yes' or 'no'. \\nQuestion: Tamika lies. Raymond says Tamika tells the truth. Willian says Raymond tells the truth. Shaunda says Willian lies. Elanor says Shaunda tells the truth. Does Elanor tell the truth?\\nAnswer: Yes\\n\\Task: Evaluate the truth value of a random Boolean function expressed as a natural-language word problem..\\nQuestion: Sherrie tells the truth. Vernell says Sherrie tells the truth. Alexis says Vernell lies. Michaela says Alexis tells the truth. Elanor says Michaela tells the truth. Does Elanor tell the truth?\\nAnswer: No\\n\\n\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['joy',\n",
       " 'anger',\n",
       " 'trust',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'trust',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'trust',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'trust',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'anger',\n",
       " 'trust',\n",
       " 'joy',\n",
       " 'trust',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'trust',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'trust',\n",
       " 'anger',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'joy',\n",
       " 'anger',\n",
       " 'joy']"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "prompts = []\n",
    "labels = []\n",
    "for i in range(nShot, len(input)):\n",
    "    if(len(tokenizer.encode(output[i], return_tensors='pt', add_special_tokens=False)[0]) == 1):\n",
    "        prompts.append(TEMPLATE + f\"{input[i]} \")\n",
    "        # prompts.append(f\"{input[i].replace('A:', '').strip()} \\nOutput only the final option (a or b).\\nA: \")\n",
    "        # prompts.append(f\"{input[i].replace('Answer:', '').strip()}\\nAnswer Format: Answer with only a single word, same or different.\\nAnswer(same/different): \")\n",
    "        # prompts.append(f\"{input[i]}\")\n",
    "        labels.append(output[i].strip().lower())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['green',\n",
       " 'blue',\n",
       " 'blue',\n",
       " 'orange',\n",
       " 'green',\n",
       " 'black',\n",
       " 'purple',\n",
       " 'purple',\n",
       " 'purple',\n",
       " 'purple']"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labels[:10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3199"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(prompts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Q: What is the color most closely matching this HCL representation: hcl(230.53, 18.02, 11.57) ?\n",
      "  choice: white\n",
      "  choice: blue\n",
      "  choice: orange\n",
      "  choice: black\n",
      "  choice: red\n",
      "  choice: brown\n",
      "  choice: yellow\n",
      "  choice: green\n",
      "  choice: gray\n",
      "  choice: purple\n",
      "A: blue\n",
      "\n",
      "Q: What is the color most closely matching this HCL representation: hcl(100.05, 97.38, 26.8) ?\n",
      "  choice: white\n",
      "  choice: blue\n",
      "  choice: orange\n",
      "  choice: black\n",
      "  choice: red\n",
      "  choice: brown\n",
      "  choice: yellow\n",
      "  choice: green\n",
      "  choice: gray\n",
      "  choice: purple\n",
      "A: \n"
     ]
    }
   ],
   "source": [
    "print(prompts[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Q: What is the color most closely matching this HCL representation: hcl(230.53, 18.02, 11.57) ?\n",
      "  choice: white\n",
      "  choice: blue\n",
      "  choice: orange\n",
      "  choice: black\n",
      "  choice: red\n",
      "  choice: brown\n",
      "  choice: yellow\n",
      "  choice: green\n",
      "  choice: gray\n",
      "  choice: purple\n",
      "A: blue\n",
      "\n",
      "Q: What is the color most closely matching this HCL representation: hcl(241.19, 80.63, 75.56) ?\n",
      "  choice: white\n",
      "  choice: blue\n",
      "  choice: orange\n",
      "  choice: black\n",
      "  choice: red\n",
      "  choice: brown\n",
      "  choice: yellow\n",
      "  choice: green\n",
      "  choice: gray\n",
      "  choice: purple\n",
      "A: \n"
     ]
    }
   ],
   "source": [
    "print(prompts[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Utils.datasetUtil import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: purple\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: purple\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: purple\n",
      "answer: purple\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: purple\n",
      "answer: blue\n",
      "answer: blue\n",
      "answer: blue\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[54], line 5\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m prompt \u001b[38;5;129;01min\u001b[39;00m prompts:\n\u001b[1;32m      2\u001b[0m     \u001b[38;5;66;03m# print(prompt)\u001b[39;00m\n\u001b[1;32m      3\u001b[0m     \u001b[38;5;66;03m# outputs = model.generate(tokenizer.encode(prompt, return_tensors='pt').to(device), do_sample=False)\u001b[39;00m\n\u001b[1;32m      4\u001b[0m     \u001b[38;5;66;03m# print(tokenizer.decode(outputs[0], skip_special_tokens=True))\u001b[39;00m\n\u001b[0;32m----> 5\u001b[0m     answer, token \u001b[38;5;241m=\u001b[39m \u001b[43mrunDefaultModel\u001b[49m\u001b[43m(\u001b[49m\u001b[43mmodel\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtokenizer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mprompt\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m      6\u001b[0m     \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124manswer:\u001b[39m\u001b[38;5;124m\"\u001b[39m \u001b[38;5;241m+\u001b[39m answer)\n",
      "File \u001b[0;32m~/BaysianOptimization/Utils/datasetUtil.py:139\u001b[0m, in \u001b[0;36mrunDefaultModel\u001b[0;34m(model, tokenizer, prompt, device)\u001b[0m\n\u001b[1;32m    137\u001b[0m \u001b[38;5;66;03m# breakpoint()\u001b[39;00m\n\u001b[1;32m    138\u001b[0m \u001b[38;5;28;01mdel\u001b[39;00m input_id, output\n\u001b[0;32m--> 139\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mstr\u001b[39m(\u001b[43mtokenizer\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdecode\u001b[49m\u001b[43m(\u001b[49m\u001b[43mpredicted_token\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mskip_special_tokens\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m)\u001b[49m), predicted_token\u001b[38;5;241m.\u001b[39mitem()\n",
      "File \u001b[0;32m~/miniconda3/envs/ALTI/lib/python3.10/site-packages/transformers/tokenization_utils_base.py:3904\u001b[0m, in \u001b[0;36mPreTrainedTokenizerBase.decode\u001b[0;34m(self, token_ids, skip_special_tokens, clean_up_tokenization_spaces, **kwargs)\u001b[0m\n\u001b[1;32m   3883\u001b[0m \u001b[38;5;250m\u001b[39m\u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m   3884\u001b[0m \u001b[38;5;124;03mConverts a sequence of ids in a string, using the tokenizer and vocabulary with options to remove special\u001b[39;00m\n\u001b[1;32m   3885\u001b[0m \u001b[38;5;124;03mtokens and clean up tokenization spaces.\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m   3901\u001b[0m \u001b[38;5;124;03m    `str`: The decoded sentence.\u001b[39;00m\n\u001b[1;32m   3902\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m   3903\u001b[0m \u001b[38;5;66;03m# Convert inputs to python lists\u001b[39;00m\n\u001b[0;32m-> 3904\u001b[0m token_ids \u001b[38;5;241m=\u001b[39m \u001b[43mto_py_obj\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtoken_ids\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   3906\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_decode(\n\u001b[1;32m   3907\u001b[0m     token_ids\u001b[38;5;241m=\u001b[39mtoken_ids,\n\u001b[1;32m   3908\u001b[0m     skip_special_tokens\u001b[38;5;241m=\u001b[39mskip_special_tokens,\n\u001b[1;32m   3909\u001b[0m     clean_up_tokenization_spaces\u001b[38;5;241m=\u001b[39mclean_up_tokenization_spaces,\n\u001b[1;32m   3910\u001b[0m     \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs,\n\u001b[1;32m   3911\u001b[0m )\n",
      "File \u001b[0;32m~/miniconda3/envs/ALTI/lib/python3.10/site-packages/transformers/utils/generic.py:275\u001b[0m, in \u001b[0;36mto_py_obj\u001b[0;34m(obj)\u001b[0m\n\u001b[1;32m    273\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m framework, test_func \u001b[38;5;129;01min\u001b[39;00m framework_to_test_func\u001b[38;5;241m.\u001b[39mitems():\n\u001b[1;32m    274\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m test_func(obj):\n\u001b[0;32m--> 275\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mframework_to_py_obj\u001b[49m\u001b[43m[\u001b[49m\u001b[43mframework\u001b[49m\u001b[43m]\u001b[49m\u001b[43m(\u001b[49m\u001b[43mobj\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    277\u001b[0m \u001b[38;5;66;03m# tolist also works on 0d np arrays\u001b[39;00m\n\u001b[1;32m    278\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28misinstance\u001b[39m(obj, np\u001b[38;5;241m.\u001b[39mnumber):\n",
      "File \u001b[0;32m~/miniconda3/envs/ALTI/lib/python3.10/site-packages/transformers/utils/generic.py:260\u001b[0m, in \u001b[0;36mto_py_obj.<locals>.<lambda>\u001b[0;34m(obj)\u001b[0m\n\u001b[1;32m    254\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mto_py_obj\u001b[39m(obj):\n\u001b[1;32m    255\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m    256\u001b[0m \u001b[38;5;124;03m    Convert a TensorFlow tensor, PyTorch tensor, Numpy array or python list to a python list.\u001b[39;00m\n\u001b[1;32m    257\u001b[0m \u001b[38;5;124;03m    \"\"\"\u001b[39;00m\n\u001b[1;32m    259\u001b[0m     framework_to_py_obj \u001b[38;5;241m=\u001b[39m {\n\u001b[0;32m--> 260\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mpt\u001b[39m\u001b[38;5;124m\"\u001b[39m: \u001b[38;5;28;01mlambda\u001b[39;00m obj: \u001b[43mobj\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdetach\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcpu\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241m.\u001b[39mtolist(),\n\u001b[1;32m    261\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mtf\u001b[39m\u001b[38;5;124m\"\u001b[39m: \u001b[38;5;28;01mlambda\u001b[39;00m obj: obj\u001b[38;5;241m.\u001b[39mnumpy()\u001b[38;5;241m.\u001b[39mtolist(),\n\u001b[1;32m    262\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mjax\u001b[39m\u001b[38;5;124m\"\u001b[39m: \u001b[38;5;28;01mlambda\u001b[39;00m obj: np\u001b[38;5;241m.\u001b[39masarray(obj)\u001b[38;5;241m.\u001b[39mtolist(),\n\u001b[1;32m    263\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mnp\u001b[39m\u001b[38;5;124m\"\u001b[39m: \u001b[38;5;28;01mlambda\u001b[39;00m obj: obj\u001b[38;5;241m.\u001b[39mtolist(),\n\u001b[1;32m    264\u001b[0m     }\n\u001b[1;32m    266\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28misinstance\u001b[39m(obj, (\u001b[38;5;28mdict\u001b[39m, UserDict)):\n\u001b[1;32m    267\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m {k: to_py_obj(v) \u001b[38;5;28;01mfor\u001b[39;00m k, v \u001b[38;5;129;01min\u001b[39;00m obj\u001b[38;5;241m.\u001b[39mitems()}\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "for prompt in prompts:\n",
    "    # print(prompt)\n",
    "    # outputs = model.generate(tokenizer.encode(prompt, return_tensors='pt').to(device), do_sample=False)\n",
    "    # print(tokenizer.decode(outputs[0], skip_special_tokens=True))\n",
    "    answer, token = runDefaultModel(model, tokenizer, prompt)\n",
    "    print(\"answer:\" + answer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[6133, 21064]"
      ]
     },
     "execution_count": 82,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.encode('correlative', add_special_tokens=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'cor'"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.decode([6133])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import load_dataset\n",
    "\n",
    "ds = load_dataset(\"fancyzhx/ag_news\") \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "ds = ds.shuffle(seed=42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'text': 'Bangladesh paralysed by strikes Opposition activists have brought many towns and cities in Bangladesh to a halt, the day after 18 people died in explosions at a political rally.',\n",
       " 'label': 0}"
      ]
     },
     "execution_count": 100,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ds['train'][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import json\n",
    "# data = []\n",
    "# for i in range(len(ds['test'])):\n",
    "#     text = ds['test'][i]['text']\n",
    "#     label = ds['test'][i]['label']\n",
    "#     if(label == 2):\n",
    "#         label = 'Business'\n",
    "#     elif(label == 3):\n",
    "#         label = 'Science'\n",
    "#     elif(label == 0):\n",
    "#         label = 'World'\n",
    "#     elif(label == 1):\n",
    "#         label = 'Sports'\n",
    "#     data.append({'text': text, 'label': label})\n",
    "# import random\n",
    "# random.shuffle(data)\n",
    "# with open('dataset/ag_news/test.json', 'w') as f:\n",
    "#     json.dump(data, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[12453]"
      ]
     },
     "execution_count": 114,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.encode('Sports')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [],
   "source": [
    "# message = [\n",
    "#     {\n",
    "#         \"role\": \"system\",\n",
    "#         \"content\": \"You are a model trained for natural language inference (NLI). Your task is to determine whether the relationship between a given premise and hypothesis is entailment, contradiction, or neutral. Output one of the three labels: entailment, contradiction, or neutral.\"\n",
    "#     },\n",
    "#     {\n",
    "#         \"role\": \"user\",\n",
    "#         \"content\": \"\"\n",
    "#     }\n",
    "# ]\n",
    "\n",
    "message = [\n",
    "    {\n",
    "        \"role\": \"system\",\n",
    "        \"content\": \"You are a news classification model. Your task is to classify news articles into one of the following four categories: World, Sports, Business, or Sci/Tech. You should respond with only the category name and no other characters.\"\n",
    "    },\n",
    "    {\n",
    "        \"role\": \"user\",\n",
    "        \"content\": \"Review: The food was okay, but the service was slow and unfriendly.\\nQuestion: What star rating would you assign to this review (1 to 5)? \"\n",
    "    }\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [],
   "source": [
    "# prompt = \"Premise: {premise}\\nHypothesis:{hypothesis}\\nQuestion: Does the premise entail, contradict, or is it neutral to the hypothesis?\"\n",
    "prompt = \"News Article: {review}\\nQuestion: Question: What category does this news article belong to?\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "tokenizer."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<|system|>\n",
      "You are a news classification model. Your task is to classify news articles into one of the following four categories: World, Sports, Business, or Sci/Tech. You should respond with only the category name and no other characters.<|end|>\n",
      "<|user|>\n",
      "Review: The food was okay, but the service was slow and unfriendly.\n",
      "Question: What star rating would you assign to this review (1 to 5)? <|end|>\n",
      "<|assistant|>\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(tokenizer.apply_chat_template(message, tokenize=False, add_generation_prompt=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {},
   "outputs": [],
   "source": [
    "def runDefaultModel(model, tokenizer, prompt):\n",
    "    # print(prompt)\n",
    "    input_id = tokenizer.encode(prompt, return_tensors='pt').to(device)\n",
    "    model.reset_hooks()\n",
    "    output = model(input_id)\n",
    "    predicted_token = torch.argmax(output[:, -1, :], dim=1)[0]\n",
    "    # breakpoint()\n",
    "    return str(tokenizer.decode(predicted_token, skip_special_tokens=True)), predicted_token.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "with open('dataset/ag_news/test.json', 'r') as f:\n",
    "    data = json.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sports\n",
      "World\n",
      "World\n",
      "Sports\n",
      "Sci\n",
      "Sci\n",
      "Sports\n",
      "Business\n",
      "Sci\n",
      "Sci\n",
      "Sci\n",
      "Sci\n",
      "World\n",
      "Sci\n",
      "Sports\n",
      "World\n",
      "Sports\n",
      "World\n",
      "Sci\n",
      "Sci\n",
      "World\n",
      "Sci\n",
      "World\n",
      "Sports\n",
      "Sports\n",
      "Sci\n",
      "Sci\n",
      "World\n",
      "Sci\n",
      "Sports\n",
      "World\n",
      "Sci\n",
      "Sports\n",
      "Sci\n",
      "World\n",
      "Business\n",
      "Sci\n",
      "Business\n",
      "World\n",
      "World\n",
      "Business\n",
      "World\n",
      "Business\n",
      "World\n",
      "Sports\n",
      "World\n",
      "Business\n",
      "Business\n",
      "Sci\n",
      "Sci\n",
      "Business\n",
      "Sports\n",
      "Sci\n",
      "Business\n",
      "Business\n",
      "Sci\n",
      "Sports\n",
      "World\n",
      "Business\n",
      "World\n",
      "Sci\n",
      "Sci\n",
      "Sci\n",
      "Sci\n",
      "Sci\n",
      "World\n",
      "Business\n",
      "Sci\n",
      "Sports\n",
      "Sports\n",
      "Business\n",
      "Business\n",
      "World\n",
      "Sci\n",
      "World\n",
      "Business\n",
      "World\n",
      "Sci\n",
      "Business\n",
      "Sci\n",
      "Business\n",
      "World\n",
      "Business\n",
      "Sci\n",
      "Sci\n",
      "World\n",
      "Sci\n",
      "Sports\n",
      "Business\n",
      "World\n",
      "Sports\n",
      "Business\n",
      "World\n",
      "Business\n",
      "Sci\n",
      "World\n",
      "World\n",
      "Business\n",
      "Sports\n",
      "World\n",
      "Business\n",
      "Sports\n",
      "Sports\n",
      "Sci\n",
      "Business\n",
      "Business\n",
      "Sports\n",
      "Business\n",
      "World\n",
      "World\n",
      "Business\n",
      "Business\n",
      "Sports\n",
      "World\n",
      "Business\n",
      "Business\n",
      "Sci\n",
      "Sci\n",
      "Business\n",
      "Sci\n",
      "Sports\n",
      "World\n",
      "Business\n",
      "Business\n",
      "Sci\n",
      "World\n",
      "Sports\n",
      "Sci\n",
      "World\n",
      "World\n",
      "World\n",
      "World\n",
      "World\n",
      "World\n",
      "Sports\n",
      "Business\n",
      "Sports\n",
      "Business\n",
      "Sci\n",
      "Business\n",
      "Sci\n",
      "Sci\n",
      "World\n",
      "Business\n",
      "Sci\n",
      "Business\n",
      "Sci\n",
      "Sports\n",
      "World\n",
      "Sports\n",
      "Sci\n",
      "Business\n",
      "Sci\n",
      "World\n",
      "Business\n",
      "Business\n",
      "Sci\n",
      "Business\n",
      "Business\n",
      "Sci\n",
      "Sci\n",
      "Business\n",
      "Sports\n",
      "World\n",
      "Sports\n",
      "Sports\n",
      "World\n",
      "World\n",
      "Sci\n",
      "Business\n",
      "Sci\n",
      "Business\n",
      "Sci\n",
      "World\n",
      "Business\n",
      "Business\n",
      "World\n",
      "World\n",
      "Sports\n",
      "Sci\n",
      "Business\n",
      "World\n",
      "World\n",
      "Sports\n",
      "Sports\n",
      "Sports\n",
      "Business\n",
      "Sports\n",
      "Sci\n",
      "Sports\n",
      "Sci\n",
      "Business\n",
      "Sports\n",
      "Business\n",
      "World\n",
      "Sports\n",
      "Sci\n",
      "Sports\n",
      "Sports\n",
      "World\n"
     ]
    }
   ],
   "source": [
    "correct = 0\n",
    "for i in range(200):\n",
    "    # message[-1]['content'] = prompt.format(premise=ds['train'][i]['premise'], hypothesis=ds['train'][i]['hypothesis'])\n",
    "    message[-1]['content'] = prompt.format(review=data[i]['text'])\n",
    "    output_logits = model(tokenizer.encode(tokenizer.apply_chat_template(message, tokenize=False, add_generation_prompt=True) + '', return_tensors='pt').to(device))\n",
    "    # output = model.generate(tokenizer.encode(tokenizer.apply_chat_template(message, tokenize=False, add_generation_prompt=True), return_tensors='pt').to(device), do_sample=False)\n",
    "    # print(tokenizer.decode(output[0], skip_special_tokens=True))\n",
    "    predicted_token = torch.argmax(output_logits[:, -1, :], dim=1)[0]\n",
    "    # print(predicted_token)\n",
    "    # print(tokenizer.decode(predicted_token, skip_special_tokens=True))\n",
    "    if(tokenizer.decode(predicted_token, skip_special_tokens=True).lower().startswith(data[i]['label'].lower())):\n",
    "        correct += 1\n",
    "    # if(tokenizer.decode(predicted_token, skip_special_tokens=True) != ds['train'][i]['label']):\n",
    "    #     print(tokenizer.decode(predicted_token, skip_special_tokens=False))\n",
    "    #     print(ds['train'][i]['label'])\n",
    "    # print(tokenizer.decode(predicted_token, skip_special_tokens=False))\n",
    "    # print(ds['train'][i]['label'])\n",
    "    # if(ds['train'][i]['label'] == 0):\n",
    "    #     print(\"entailment\")\n",
    "    # if(ds['train'][i]['label'] == 1):\n",
    "    #     print(\"neutral\")\n",
    "    # if(ds['train'][i]['label'] == 2):\n",
    "    #     print(\"contradiction\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.575"
      ]
     },
     "execution_count": 108,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "correct / 200"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'<|assistant|>'"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.decode(output[0][-5])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[32006,   887,   526,   263, 19688,  7418,  1904, 29889,  3575,  3414,\n",
       "           338,   304,   770,  1598,   612,   295, 29886, 21804,  2729,   373,\n",
       "           263,  5810, 21700,   515, 29871, 29896,   313,  1201,  8178, 29897,\n",
       "           304, 29871, 29945,   313,  1201,  6374,   467,   887,   526,   263,\n",
       "         19688,  7418,  1904, 29889,  3575,  3414,   338,   304,   770,  1598,\n",
       "           612,   295, 29886, 21804,  2729,   373,   263,  5810, 21700,   515,\n",
       "         29871, 29896,   313,  1201,  8178, 29897,   304, 29871, 29945,   313,\n",
       "          1201,  6374,   467,   887,   881, 10049,   411,   871,   263,  2323,\n",
       "         13615,   313, 29896, 29892, 29871, 29906, 29892, 29871, 29941, 29892,\n",
       "         29871, 29946, 29892,   470, 29871, 29945, 29897,   322,   694,   916,\n",
       "          4890, 29889, 32007, 32010, 13957, 29901,  3826,   296,  3464, 10579,\n",
       "          3802,   304,   278,  4272, 29889, 29871,   450,   286,  1446,   526,\n",
       "          5051,  7773, 29936,  3138, 29892,   278, 17455,  3464,  4225,   304,\n",
       "           367,   260,  2760,  2086, 29889, 29871,   739, 29915, 29879,   763,\n",
       "         29425,   714,   310,  3148,  4673,  1134, 12164,   856,  1333,  1407,\n",
       "           626, 12007,   304,  4120, 18499, 29889, 29871,  8449,  2924,   310,\n",
       "          8686,  1446,   278,  6437,   310,  2675,   304,   263, 29416,  3464,\n",
       "           856,   855,   453,  4947, 29871, 29941, 10819,  1363,   278,  3464,\n",
       "           338, 11872,   701,   472,  4646,   607,   338, 15129,   363,  1906,\n",
       "           310,   502,  1058,   526,   788, 18186,   304,   445, 21863,   292,\n",
       "          3748, 29892,   541,   526, 10579,  3273,   373,   931,   313, 29882,\n",
       "          5555,   263,  4982,  2924, 29874,   480,  4684,  6041, 29892,   694,\n",
       "         29973,   467,    13, 16492, 29901,  1724,  5810, 21700,   723,   366,\n",
       "          3566,   304,   445,  9076,   313, 29896,   304, 29871, 29945,   511,\n",
       "          1962,  4153, 29973,    13, 22550, 29901, 29871, 32007, 32001, 29871,\n",
       "         29941, 32007, 32000]], device='cuda:0')"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<|system|>\n",
      "You are a model trained for natural language inference (NLI). Your task is to determine whether the relationship between a given premise and hypothesis is entailment, contradiction, or neutral. Output one of the three labels: entailment, contradiction, or neutral.<|end|>\n",
      "<|user|>\n",
      "Premise: A man is riding a bicycle on a busy street.\n",
      "Hypothesis: A man is walking his bicycle down a quiet street.\n",
      "Question: Does the premise entail, contradict, or is it neutral to the hypothesis?<|end|>\n",
      "<|assistant|>\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(tokenizer.apply_chat_template(message, tokenize=False, add_generation_prompt=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "435515b2dcd14789b7011052b9069f78",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "output = model.generate(tokenizer.encode(tokenizer.apply_chat_template(message, tokenize=False, add_generation_prompt=True), return_tensors='pt').to(device), do_sample=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "You are a model trained for natural language inference (NLI). Your task is to determine whether the relationship between a given premise and hypothesis is entailment, contradiction, or neutral. Output one of the three labels: entailment, contradiction, or neutral. Premise: A man is riding a bicycle on a busy street.\n",
      "Hypothesis: A man is walking his bicycle down a quiet street.\n",
      "Question: Does the premise entail, contradict, or is it neutral to the hypothesis? Contradiction. The premise describes a man\n"
     ]
    }
   ],
   "source": [
    "print(tokenizer.decode(output[0], skip_special_tokens=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "output_logits = model(tokenizer.encode(tokenizer.apply_chat_template(message, tokenize=False, add_generation_prompt=True), return_tensors='pt').to(device))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "predicted_token = torch.argmax(output_logits[:, -1, :], dim=1)[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Con'"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.decode(predicted_token, skip_special_tokens=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ALTI",
   "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
