{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Eyeglasses Regression Case Study"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.environ['KMP_WARNINGS'] = 'off'\n",
    "\n",
    "\n",
    "from pipelines import *\n",
    "import os\n",
    "import sys\n",
    "import warnings\n",
    "\n",
    "if not sys.warnoptions:\n",
    "    warnings.simplefilter(\"ignore\")\n",
    "    os.environ[\"PYTHONWARNINGS\"] = \"ignore\" # Also affect subprocesses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from ripser import ripser"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1999"
     ]
    }
   ],
   "source": [
    "import tadasets\n",
    "from ripser import ripser, Rips\n",
    "import gudhi as gd\n",
    "\n",
    "n_data = 2000\n",
    "\n",
    "np.random.seed(565656)\n",
    "\n",
    "R = np.random.normal(loc=10.0,scale=2.5,size=(n_data,))\n",
    "\n",
    "clouds = [tadasets.eyeglasses(n=200,r1=20,r2=r,noise=1) for r in R]\n",
    "\n",
    "DGMS = []\n",
    "\n",
    "for i,cloud in enumerate(clouds):\n",
    "    print(i,end='\\r')\n",
    "    A_complex = gd.AlphaComplex(points = cloud)\n",
    "    A_complex_tree = A_complex.create_simplex_tree()\n",
    "    A_complex_tree.compute_persistence()\n",
    "    dgm = A_complex_tree.persistence_intervals_in_dimension(1)\n",
    "\n",
    "    DGMS.append(dgm)\n",
    "    \n",
    "#rips = Rips()\n",
    "\n",
    "#DGMS = [rips.transform(cloud)[1] for cloud in clouds]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2000"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(DGMS)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjIAAAGdCAYAAAAIbpn/AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjcsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvTLEjVAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAralJREFUeJztnQl8E2X6x39Jepe29C5FUAQBOQSRW1RQoCwIuuuJq+J6/D1wFfEAdl0BdQVEEe9rvZD1xAuV5VpQQU5BFER0RQQEelBKW3rn+H+eN5l0MplJZtK0zfF8d2vIzGQyk0zmfd7n+D0mh8PhAMMwDMMwTBhibu0DYBiGYRiGCRQ2ZBiGYRiGCVvYkGEYhmEYJmxhQ4ZhGIZhmLCFDRmGYRiGYcIWNmQYhmEYhglb2JBhGIZhGCZsYUOGYRiGYZiwJQZhjt1ux+HDh5GSkgKTydTah8MwDMMwjA5Ij7eyshL5+fkwm83Ra8iQEdOhQ4fWPgyGYRiGYQLg4MGDOOmkkxC1hgx5YqQPIjU1tbUPh2EYhmEYHVRUVAhHhDSOR60hI4WTyIhhQ4ZhGIZhwoumpoVwsi/DMAzDMGELGzIMwzAMw4QtbMgwDMMwDBO2sCHDMAzDMEzYwoYMwzAMwzBhCxsyDMMwDMOELWzIMAzDMAwTtrAhwzAMwzBM2BL2gngM09zY7A5s2XcMxZW1yElJwMBOGbCYua8XwzBMKMCGDMP4YPmuI5j96W4cKa91L2uXloCZ43tgTK92LW4AsVHFMAzjCRsyDKOCzW7DC5tXYeHabbBbqQ9IJ3cktrC8Frcu3o7nr+6nacw0xQDSojn2yTAME+6YHNRHO8ybTqWlpaG8vJx7LTFBYfX+1Zi7ZS6Kqovcy+wNaagrGg9rZS/xnPwqeWkJWD/tfC8vCxkcZOgof1jSVr4MIC2aY58MwzCRMH5zsi8TPdhtwL51wM4lzkd6rmLETP1iqocRQ5hiypHQfjFiUnaJ52RQkGeEQkfyfdu/fx9LP3kPJti99i0ZIeRVoRCRXmhbeo3aKwLdJ8MwTKTAoSUmOti9FFg+Dag43LgsNR8YMw/oMcEdTiJPjEPFZKDmrOS7jM/9FNbKHu45AOW/yPdNS58DcDg+A7MbrsUK+0CP/cgNoCGdMxtXkCG0fwNwoghokwucPBQwW8Qq2lYeTlKiuU+GYZgogA0ZJvIhQ+O9a2X+CxcVR5zLL18kjJntxdu9PDFKY8YUW47eyV+gU00CitEW3Y8dA776q9e+83AMz8cuxK0NU7yMGbcBpNPI8tjWB3q3YxiGiSTYkGEiG/J0kJGgGZgxAcunA93HoaS6RNcub014C2Nt1c49rDO7902Bqu0J8SixWJBts6FvTR1mxi5CRUMSslEhDJ8t9u6wwyyqmPQaWTkpZ+s6Lvc+GYZhogg2ZJjIhsI1ck+HFw6g4pDYLjspW9cuD8Q2/mxMDmcuzOqkRMzNTEdRTOO6XKsV00vL8Hb1I+5lpY4UPB57MwZ2GqvbyBp4x/eiOomqpdS2lBKPqbybYRgm2uBkXyayoZwTndv1y+mHnMQc39s5HFiS0kZ4XyTIiJmak4UiizOnRaLYYhHLab1EpqkS/7Q+BsvqB3QbWZaDG0WJNaFUoZGe03oW6WMYJhphQ4aJCChRd2vhViz7dZl4pOcCSpzVQ5tcWMwWXNb1Mt/bmUzC60IhJPG+gPDEOKQkGhkO1/N5mekeho9YuuEp4MfP9B3biSJRWk0l1uR5kUPPufSaYZhohkNLTETqvuQm5WL6wOkYefIIZ+Is5ZyoBGYcMKEmMRffWbthoN2Bjqkddb0n5cEQZNDIw0le+zeZUBgTg60J8aBXSPkz/WrrYP/234jV82YuY4yMmVE98kR1UmFFLY6dqENGchzSEuNE6XWwPTJkDFICNOUOUdiNPFZk7DEMw0SNITNnzhx8+OGH2LNnDxITEzF06FDMmzcP3bp1c29DenyzZ8/GSy+9hLKyMgwaNAjPPvssevbs2ZyHxkQIku6LsmS6uLpYLF8wfAFGUvWPSKilgb5xO5Hd4nDgrvIrseKVrSIP5erh+pyUZIzIDRp/3J2ThQrZtlL+zFkNqWiLSpi0sl/ICKNSbBdkrJTX1OPR5XuaVeHXt3E4MijvwTAME/KhpS+//BKTJ0/Gpk2bsGrVKlitVowePRpVVVXubR599FEsWLAAzzzzDLZu3Yq8vDyMGjUKlZWVzXloTCtC3oONe0vxyY5D4jFQITdfui/Ssnlb5sHWfZyzxDrVc5AvdGR6lEdTMu1jnzQgLTYLJq9sFCcmhwN5VqvwqJApU2rR9xOqMHtuR/k0d+VkYV58b2HMk2fI8/idps1PZ/4dNtnPVFL4VerKSG0TaH1T0RIFlIxDWs8wDBOVLQpKSkqQk5MjDJxzzz1X3MDz8/MxZcoUTJtG1RtAXV0dcnNzhefm5ptv9rtPblEQXgSzXxDlwly/4nq/271a8CoG5A0QVUK2377G7LfW4OfqZHcptBwyJ7Jyf0JdxuviudxIIiOGWFB8VDwqq5RUkX5eivwZaZ3JFochey/Eg3GLkYtS96rDjkzMbrhGGFnS50NhpWHz1miK4/lqm2DEOCz4oEBTT4cMPPLMLL9kOYeZGIZpEsEav1s0R4YOlsjIcJaJ7tu3D4WFhcJLIxEfH4/zzjsPGzZs0GXIMOGDVr8gPU0Y1dCr++LezmzBFkdPLDqh7e2jYysp6oZ7h87GRwee9Qyt2GyYVlom/k3VSH5nAGTEqBkwEiYTHDEN+DJvL4YcfhKP9j+Br7bv8tCbkX8+U0Z2DZrCr1b+iz9RQDLsCqsLsbVwGxw1nYPa2ZthGCakDRnyvkydOhXDhg1Dr17OxntkxBDkgZFDz/fv36+6H/LY0J/comNCH3/9gmgIpPXkdVAOiPRaGpyVg6Ze3ZfMxEzD6rcnxQ/Eikucar8l+9che+1cEU4iCjrkq1YpKYm3x6DO4t3PSUlM6veiw/ZDe89AuX2wIuJrhzlpH8wxlXh1G/0mOviNCPs7R1/5L/W2eujh9ve+wNHCRkOSu3AzDBPxhsztt9+O77//HuvXr/daZ1KWrZLLXWOQoARiSg5mwotA+wX5CkWN6tFPDMCUu6GWJyPx9/V/dyep6lW/pe3IQ0EhKVvWmbB++SLMKMI3CXH+w0kA6o8NRpb9BOqynE0mfUGXenzm17DjayRnNnbZpgaV1NvJHFvuTk6Wr/d17IEmR9/W5zbooawiISheNYZhmLDQkfnrX/+KpUuXYu3atTjppJPcyymxV+6ZkSguLvby0kjMmDFDhKikv4MHDzbz0TPBIJB+Qf4SW1ftLhYGCqGVnKtMUiVvDhlCWlvT8nYylVw6hmHzv8Qdx68UBnaxzvLjuIxNOKrDiPF6f1eX7bjsZeKRnssxx5Qjsf1ixKZ87/fYA0mOXvLzEmEcan6eDsDekAZbdSflYgF34WYYJqIMGbrxkyeGSrDXrFmDTp08b370nIwZqmiSqK+vF8nAVKqtBuXQUFKQ/I8JfYx4QvSEoghaP6LDBaLEOjtRO8wkr2Aiv4aWSq6077G9nFoty74/7DakKOmWKpwSbHFoTiRHZFzmOo/njRvQ/x3okLcYo82b5Yt9KvySEfOPtS/4zX8pqinCpV0vde3TpPr5kEdI7dYh96oxDMNERGiJSq/feustfPLJJ0hJSXF7XihLmXRlKHxEFUuPPPIITjvtNPFH/05KSsJVV13VnIfGtDCSJ0RvvyAaDIvKqzHYvAc5OO6VACsfNEd2Hok2sW1w06qb/Capbv/udYzpc50IgShDVjT+UyX4K1//Jv7IiFAe67m1x5FmS0Y5lVOrhD/95ffqwfl6h0+RvZIYE+akvIBuJ37Hfkc7WJNzMGHCJe6wjjyZ90DFAbz5wzuosDZWRfmioq5CGIfKPJq02GwU7ivwGdYiuAs3wzARY8g8//zz4nH48OEey1977TVcd9114t/33XcfampqcNttt7kF8VauXCkMHyYCoFYB+zfAcqIITw6KwcSVFmGMyIdpNW+C5adPsT5+NvJNjbP7w44MzG641q37Ih80j9Xq8wKUrL4fWPsYxoyZh1HTxgtDaNXuQrz69W/CiJEjFyYwkycndhHWJiU6jRgNmmrEGOFojAV3x37gfNIAYNULgGUeVicneRkh7oxqHXz262e4u//dGNFhhEdlU/2Jk/Hn77f6fT134WYYJmIMGT0SNeSVmTVrlvhjIozdS53dnV2NEcn82JWeJ4yRd070dW+Wp9SR2b0UA7ZM8crlyMMxPB+70EPETho09VYwCUXeqiNC6ddy+SIM7D4eU9/b4fd1A817kGs6hmuz8lveYtEgx6Uu7KbiCFZ/djOm5qqUhhs43LK6MmHAUKKz0N9xQeE+7sLNMEyowb2WmOYzYkRbAM8hNbGmCHMwH38peBZ70od7a5CQB4eMHzhEqEeOFPqZGfsmVtf1R05akjsURTooviqYSMyOdGCkEmoxsi+fji2xg31WU0lQeMtfX6Wg4XCIAJpdw2DyPhcnNjgwN7OtcwLRRENLTaOHviMyOClvyLPZA3fhZhim9eDu10zwkRkj3jjF+Lt9+09cdEaeKLX2SE7dv0F4cLSGYdo031SKAeY9nqEos0VUMAkjRvG2kiIvidk11hw5gIpDQulXD5Sjo7evkhqUOJsWl6Z7+0nlLn0kpVdTtDNQnosTt6EVBG+RloeLu3AzDBNqsEeGCT4uY0QbpxEhtut0jueqE9pVNXJmDGuLPjK9Ekpu/emwFXWlZyM2bQfMMVVeirwjq2u89pNjOi78Lf6gRONJ1mRdx6Z0iAhbxOTA1adfjWe/e9bv6ycfL0eXekp6MUZTDC1lCwLycGkh78LNyr4Mw7Q2bMgwwUdhjNhc3gIaaLNdIRGLhtHyvx934DQdb9Hn9O6qSrXxLi09szUef64qwYjqmsb3U6HzqZ2RkVyHY1W+FW0pQfmjyquQa30fxRaLqBxS1VixJQGOGJhiGxWnHdY0JFb+Cdf3uhFL/rfEp4BfblxbXH/8AMZ20MjFMZmEh2leZro4N4tKR269aBlc9w64D1v2HfdppNBzf20QGIZhWgI2ZJjg06ZRzHB1UqJXc8VcqxXTyUMi245YvvN39Pnh384CG1/RkZR84OShPpVqbZY6vJmagr416kYMBbhMqfmwnHI2Hr6oGLe9td3nKWUkx+IPF94sHE2Pl3wojAkPY8YV0aor/BOslT1gSdoHU0wlHNYUIR5XBTO27S8X4S86XvJ8eDSkdAXTpg/5B74rmYKiGG3vCr1vYUyMMA4HyPJkyGCjz1bT0JLvQ8WOIoPLUnYxHnjLhMKKTU1uP6DVz4lhGCaYsCHDBB8yMlLzsdp6HFNzMr18DzTQ3pWThTu//RQ3ura3wYylSz/AGFm5tSZnXScaQPpSqhXjuMOER7PSMeJADWJl4zolDIv1Y+aK/Yw9ox1u/r0TXvxqn+rb0aaP/LG3cyA/80G0/20Y5m58CEX1xxv3afVsHWCr7uy1H/JwXNR3pKpGC4Vzpg24FyMdiVjWoT9Q8a3hUBI9IwORPlt/xFqT0K24B6psGdhjSYfdmupS6zWjHPIkYjtKGn7AX5duwpTKs3DLoFG6jBFf/ZyoVQTDMEywMDn01EhHQRtwxj9azRtVt/3hYxRsmoEiGmx9VN4sP3gYltR8/HTm/Xh21W48FfeM/wO55BWg96XYWrgV16+43u/mjx6uwR/qGqtwCpGJ7MuegKXnRR7bffbdQdy/4lOcsJa5PSnt0pJUvRFyb0NxWRxmvV/jN3f+7ZsGu8MxXt6K0kOwrJghcou2JsTj+nbqLTrkvHqkyMMjI/YL4LyO7VGulS/jANJsdqw5+DvifOjzEMpeT3qNES0vmdPr5MCCTpdjZIfhToOXPTQME7VUBGn8Zo8MowtfzRvVQg7bM9v7LFWWh0f6VxxB1y8n42TTn/QdjCskpVYirMYdjutwVn28WyH4uokTMaZnY88vafBd+PNc2HKLkOhalh6XjfuHzMDoU7zPT2ooKRl4L65co1u1WPl6Uar+PglEOnSFiLTKrwn6PDWNGNfBlMeY8Z0sLKWmz0NGDPV6UkIeFjJSyKukZsz46+ck8nv+9xZGrHlMGLAYMw/oMUH7eBmGYfzA5deMX/w1b6T1SvQaGRQeoWwRYmLMWhxxZHgp7ErQ8rqkdu78GL0ieBQ22WTvgXUJ5+G6q67GmN7eRgwNzso+RMfrj+KeL+8W630h6asQKq2RfPZAUitVl0JE4vUaDlO18msjlUvy7aTDIn0eUjCmcBJ5YsT7a6TaUN8qMlqUkJfJZz8nmQFLAn5Ca4gMOYZhmABhQybaocFo3zpg5xJg7xfAr186/03L7DbdzRtpOzmGlHbFgO8Q7Qjesp7vPCzFG0p5LTHj5rnDEZIInlanZoerU3MbR1dMveBUfHN1AsY4vnafm96O0FqDdlD0VTRK1alUfEHxUS/13rykXCw4YcfIanURv2ybkNHzi7LCSdLnIQVjSlSmcJKWEePuW1W8vUkGrPsKWj7d/X0wDMMYhUNL0YyihYAXqfn45cz7caS8rXhKs/WBKk0cpeaN8nJcMjIoNHOsrkR1QNQKj+x35OG2hil4IHYR8nHMI6+laMhMnCnLa5FE8NSqgMR7mIBbe9+NW4bUwbLiT8DXsvN0hTW2Z7Tz2xFaGrTlcv1B01fxoZtDxgyVWIvS9SG3Irvbhc7Knz2fu1STvfV1RVgqNhXFDZU6FY49oe/WFJMEPagZLUYNWJ+aQgzDMDpgQyZa0Wgh4IErd6XAfKd4Sk0TtZo4Kjsek5FB+SV3U9KnQq9EXWnXydUjB+DOzSkYVt7fbTS5OzsrQkIE5WmoVQHlJeVh2sBpGFlVrX6errBGyQV36/q49HoaDOurKErQvfYHOHNZOo4EJEOKckouX+RthFI5+Zi5mJ6cpF7i7eNzlyAD1WGN13XoakaL8VYRxoQQGYZhlHDVUjRCbvyFvfyo7zbqrZQ5ktEWJ8RzuXNBCv/c1nAH/jpuMHqm1jgHZlk1yvx17+P1n570qHzJs1pVlHZNTi/JlJ2iFNuoaqyqZgmt8HmeJmzNyMf1af7zSl4teNWvR6Zp3wXlGWmkCrs+F68KH1dncWEEKD53tfLnPJsD046WYmR1tde7OFxer7NrnxRZMsld5sEUox5ektR/l1+yXLUUW8o5cu7X25CikJmXyvKkz9gjwzBRRkWQqpbYkIlGKEfkjQsNvYSMFtVcVRKCM5lhcbY4dKKoRlm283fMXPkZOtRvwTR8Jmbjcl0Xd0oseRmCWcGi4zwpwFHQ7QwU15erexD8DNrB9Y5BvRWjwc9FMuqKqopEJ+v0+HTkJuc6S7xFdZTn+4hvzgHNqiUPb5rrmNSqluTl+b/XbcFHB571NKT8GLBcis0w0UUFl18zAROAG1/LIeJcrkgwlapRXAPw2N4noaDnzdiy7zKYfjoX9l1zgOpCheEzN/hluDrOU1QItR+Nqfve11TbpRBVsyrS+ggVGf1cfAnRWXpeDJi836fQkYnZDdd46MiQsF/toatF9ZJJoSMjQnYKI8a7PD8OeWnTcMtwGzpZtyL762dcrSJUDDWXMCHDMEwgsEcmGgnAI2OcwEIirXKekz7DanOddp5NSynRNvFz8S1EJ/OiUDXab19j9ltr8HN1sjtpW+OgRBXTHaPzMPSUTqptBqTyfKU/S7J9RdWWeauHASX6b2W0R8mZE5F92hhuX8AwUUgFh5aC+0FEFX7zMoJIa+Y+GMw/CefeQHTsBR8UaFZgKUNkG/eWYuLLjf2U/PHklX1xUd/2Xu+5tXAbbn/vC5RVJLhbHHi+r7MEff20853hx/0bsPrgF5h7aKVHiwfJazSiw4iw/Q4YhjEGh5aYwKGBgXJYVEt4g0xrVqP4PE/vsIaH2m6Y4VeITlFGrqwy8wclXWuGsNKBpHSnZo+835TzfeFRnk+er7v2vee1f9rPXV/chbS4NJTXG2uJwDBMdMOCeBEMJV/SzPuTHYfEo4donZSXkWqso7Fh/JQXNzta50memGAnF7ciuoXoXNspDRNfZCbHebRX0FJCpionShCmRGElZDiRB2fWxlk+30tuxIjXVReL9/KnrswwTPTCOjJR1BupbWIs/nJ2J9x+fhdnOTMN4nY7sGRSMxyBK2zjaifQqtB5dh/XMnk5rYRuITrXdmSY0PVwvKbB72su6pvvLn/313GcKqwpQdha2cNjnkSGEzX5LK/zNFT8IfozwSTUlSnsxGEmhmGUsEcminoj0aD1xOqfcdbDq5z9kSiHZOWMgN6DkjWpS/Oy5CTx6CkwH4LVKHQclKvT+1LnY6gcV5Dw166BllPyMm1HkGFCRq0eSK1YbwiLjBnSDKIEYef7OpuLkuG0tWgrAsFXSwSGYRg2ZCIMX72RJI5XN+CWxdux5YtPdYniKVmdlIiCDvm4vl0upuVkiUd6TssjMWwTDkjtGgilMaNVRk6eubZJsT73KxkhRkNYpphK74aZTUzF0vveDMNEF2zIRBiUVKn0xGjx2YYdhvdPxsrUnCwUKbosF8fEYGpuNlaPewi2O3Zga0Y7LPt1mQgn+Gu4yAQHqV1DTlKOx3Ly1KgJ2JFxMfdPvVX3ZXL9Kbt26w1hOawp7oaZo3rkiOvA7tDX0FILve/NMEx0wTkyEYaRahTSEEGc/n2TOTI3M905sVZo1ztcM//Ze9/HnH2foLim2L2OK09aDjJWjJQwU6PLF67u55VPRUYIGTHKrt3+eikRabHZeOGqKzH4lAys/fY5FLzzLooaKvwfvLIpl2wxNSCVwmIMwzBy2JCJMIxUo5AQWk1CLhJri33rrDTUAjWlogtzUYz2JUMD2/G6Rm0QZeWJmleACT5Gy8iNdO321XFcCmHNOvtvOLtqE1a/MB1T25hVDV8vo8XVh0m5XFpcW0TChuxAZhjGG74zRBg0AFFegx5IzfXAoJmuZ8pBS5awO36heF5iCczulQY7qjzhMFNoInXtJtE7evTVpNNvCKuqGrb3rsXcRNc3r9Z5UgF1xP5LeYV4lOOwpolWCSVF3YShxTAMo4Q9MhEGDUAUElCTjFdTXO1y3lVAwx5g4zON01+xgQkYcntjwu7li5C92plMGghKQTYmQkNYtHJhL2xPiPPpvZOMm/NPVKN/XS2uqDghopy3l5Xj3dQ2OBgTgy21Q7Dj2ET3bcqoiB/DMNEBGzIRCIUKKMly+oc7RYWSEo9qkj2fAhue9g4tUWImLT9pgNOY6TEB/bqOQe77F6C4/njABShceRLhISzqb1VxGCXJSbr2saZNkvh7Iy0VY09UYVmb5EYDKO0HJGfMd6sFGwmbMgwTPXBoKYKNmW33j8JdI08TwmdypGqSMT1ynI38NMwSsXT5dKfeDA1cMXGYPnSmKxvCf7hADa48iXBcLSmyFSEif1AV3GtpqV7VcJJacHbuTx5l4AzDMBLskYnwMNOdI7vi9vNPU0/kdM2etaBUTlQcciriuho/SvkRyk7RlB9Ra61FRX2Fuuqrq2khV55EOK6WFP1q65BrtToNEx05Mm5ZYMW20uKE3M8A3ElXdXMdOcMwYQobMlGUyBloQ8fvftyDPrIO1lr5EWsPrvVZzaIUZGMiEGr9kJoPS8URESoiL4tuNAweWny8ocRQflU4dzJnGMYYbMhEMxoNHSkoQKXWJRaLCBG8+u0JPDPG4VHJopYf4ctbQ0YMl15HAa6O46s+uxmvGzFigphf5dGZ2wVrGTFM5MKGTKRB+Sx6myOePBR1SXmIrSqEZKOQci+J3skrTuwNS/DC1lMwedAfgy7IxkQe9V3H4m+ZHeBAtb6wUhDzq6TO3MrwJmsZMUzkwoZMJLF7qTN5V573QoJ2Y+ap9z0yW/Bdrxnov/lO2B3AmmRn+wFlhosppgIv7HkA3fJSdHlVjAqyMZHFW999gdqYGhVtosDQm1/lqzM3d9FmmMiFq5YiyYh571rv5N2KI87ltF4FW7fxuLVhCg4hQ7P9gPSUBe0YPRyoKAzaB2Ukv8pfZ27uos0wkQkbMpESTtIso3bOTx2yMmo5VMH0fcq5ON8yxRlO8hEKkATtGMYXHVPzDH9AeUl5+EvPvwjPi56Gl+Japqq7nUucj3ab7hwa1jJimMiCQ0uRgM4y6i1ffIqB51+sqgT816WbdL0VDwKMP67qMxwLvmsLu/m4ql0sqqxtaXhxzGM4XnfMI4/qzn53+s+v0gihHuhdoOvLYS0jhoks2JAJ9wReuql/eoeu3SxevRXHcgZ5dTSm51Mqz8ILP7/jdx88CDD+iIuJwTWn3YE39j6o2Rvy2q53Ymj7wcbzq6QQqsL7uNp6HM8dWu3To8haRgwTmbAhE84JvITKTV2LYrTF7E93i07HyqaAtwwahY9+z/WZY0Dufxa0Y/Rw7zmXicc3//cUHJbGjuhmW1tc0/UO9/pghFApYDo3s63fXwEFWVnLiGEiDzZkQhmN2ac7gTexrS4jhmbBZWiDLfbusJfXCpVfpUAezYQL8m4Ws2hCbRY9Ou//uIya0Q0ZK3cO+aOoYqIEYMqdobATeWwCgrySKiFU0jzy2aDSxeQ+k1nLiGEiEDZkwjSBV1BTpnt36TiBUeZvsMI+ULWLsM3uwIfrM1BrvxrxuZ/CFFve+G7WNNG478MjGZh6tqcwHsP4goyW687yXbJP155qCw0/StSScOOqpERdX0LH1I78ZTFMBMKGTKiiMfsMBPKukE7MzNg3saquv2oXYRpIjpSTgdML1soesCTtgymmEg5rCmzVnUSB2xGoe3MYJlCW7zoiwp3Oa89Ju7QEkYCuzOWSK1GrCTf6g/O7GCYy4fLrUEVnHyS90AQ331SKMSm/qnYR9vTSmGGr7gxrRV/xKL9M1Lw5DBOoEXPr4u0eRgxRWF4rltN6j+1PdMJhRwZWJjqFG5Wdst0xUJUkX87vYpjIhT0yYdYHKRDkvZPOOe0Yxa28ugireWnU0Lsdw/i8Ju0O4YnRCpxSYEmemC62/+wn9G64Br9mva8q3KhWscQNSxkm8mGPTKjmxzjsrmReT4Nka0I8liUnYUt8vHjuD3LBF3TIx/XtcjEtJwuPlH+Igg8KRE8aOeSlIZe+VvYLLaf1at4chjFKYyhTHTJUaD1tJ9/+vwlZfoUbdQnqMQwTMbBHJgzKremm/l+VnIBcqxXTS8swspr62qgbMWq9k9Qa6EnCeOTSpyFC/hppyKD1nOjLBAO9IcoN/yvCQNMPiP1xDwaby7Etpk7X6yZ2m4hRp4zihqUMEwWwRyYM+iWt1sgJKLZYxHIyWJQ4tTXUeydJTfWUvZMoufL5q/shL80zfETPablX8iXDBIieEGWBeQsmbhwHy6Lx6P/NvXgn7mE8ZXpd1/7JiCFhPe66zjCRD3tkQgUfYl/zsjQMEpMJJocD8zLTMaK6xiPrxZ+2hryBnlxJlYwVykvQVQ7LMAEihTIpsdehYcQ8H7vQa/nI2hLkWvNRZKHwktqF7UC6Hehz9CDAHdgZJipgj0yI90tyGyQaOQFkzBTGxIjt5FBib6C9k8hooRLri/q2F49sxDDBRgplEsor2ww7ZsYucv5bsTLWBNx3lPSTHOoSSyYTyiwmjN38d6xeP4e/OIaJAtiQaWGo+mLj3lJ8suOQeKTnIqS05DrV7XUbJB7bmZARn67rdW3jOXmXaR20QpkDzXuQbzrmZcRIjK6pwV/KK3yqWlMYduov/8bq31YG+7AZhgkxOLTUyuJfV7bZgTnW+c4O1Spk2/TUJjVu53AVnB7schVQ8q7f1+05UoGh7XWfAsMEFSmU+cSqn/DM2r1iWQ4aezOpQVf6sjbJvndMHkwKu256GCM6XsC5MgwTwbAh08LiXw6FC/2Ohn+JfBWtatJ+tXWiOokSeymM5IXDgTybTWxH1CflIf7CR/FjEc1Y/fN7ZXFA58MwwQwznd0l223IUHNTX+jtrSTCrnVl2Fq4VRgyFEYldV9qfMpJwAwTObAh04riX5IL3RcUMKKcgHtysxqVwjyETE2ILboAd9WniQFg4kVX4KIeHdGxxlMnRgtq5McwoZT8S81NScE3D+rhpWKzvnCrxN1f3o2K+goPbZnpA6eztgxjrBiD2saQ4jqJlZ48FDB4HTLNB+fItKL4lz8XusRwaxz6lJwNuzXNYzk1c6w9dDV2V/wBS+2DhVjeb3WbxAz0it7nwGRrq6XaLpabrG1FN2KGCaXkXzvMmN1AXd+dPcLk0PMsneFWCbkRI9dRUopCMowquz4GHjsNeONC4IMbnI8LezlzG5mQgD0yrSj+5c+FLhE38U280vEcDJqzChWOn7yaOcak7BIdq82x5fjXTxB/NOs8N38Uvih832m0eHlygGu63iG6EzNMKCX//u2jnVhRNRC3NkwR1Uv5aPRaFiITr1ReDXvDGnG9B4II5cIkdJRGdBjBYSZGm5X/ADY85b2cKkxJ8+vyRUCPCfwJtjI8irWi+Jc/F7qII6XmA6cMQ5zZjDl/PAO3LraKNdJElYyYhPaLvV5Js87i6iUYnncZvjq8Cg5Lo/fHbGsrjJh7z7ksOCfIMEE0Zs7vnovBc/4rjBnq1k4hWPJekuFPvxny2MQUJYvrXvxsApA40tJRYhg3P3ysbsTIriIsnw50H8dhplaGDZkW4KyT04Wh4uUmd7nQSfiL1nkaM64nY+a6fyTSjLWx8skuPDFqN3Np1vlT5Tpsvno13t25DgcqCkVODIWT2BPDhCpxMWY88sderuR4MzbZnSEnOdbKXiKsKnkiA2XVb6vEIycAM145MZ/f7f9DqTjkzJ3pdA5/gK2IyeHQyqIIDyoqKpCWloby8nKkpqYiFCG9mIkvb9JcTyqmwoUuT/xNbe80YlTclpQ8THk3m45sxqt7SQ3YN68WvMqzTiYi5Aq8scOStA/mmHK0aVOHpOy1XjkxeuAE4MhHum/qUiwngVLKhdHDJa8AvS8N6rFGC8Eav9kjEwIN8lbYnS70RRdYMSzP5jcrXlLeLaPfoLNi1bB6L8OEOvJ2GV//chTPrP1FZSszbNWdhbZMhXUvrGnGjRitRqpM5FQHqRnFVCVHCeaqPeTo/fVC29JxcxVTq8GGTIg0yKMwk+XUc4HOmbr3S5oYwdyOYUINyWjX0y2bkuADRQrFzt08F21i2+BY7THWnGlpqAqI+s3JW7VQjuCYeU1KqFXT8CKo1J+WyxviSl4bW6EFw/S+wYq/ARufafJxMoHDhkwINMgjxwrJtNN2RqC4PrnEaTYpdbT23K9JrKftGCbSJwNUydcU6DdUVFOEm1bd5F7GIacWNGKoCkh5H6s40qTqIC0NL0KS5aL15PlbtbvQ7bUxIwbr4zPQznRMXy55E4+TaRqsI9PKDfJMIsa/FxPOLsL24m9gIxel7v1ahLCXcz+ee5aeTxs4jctLmYiZDPgaVEiOwN6QpqmdFAisOdMC0D2PPDGa5ga5VaY7twuShpd877T+mTX/wy2Lt7u3lQox6FrSdz017TiZpsGGTCs2yKPS6ZSujyLx5Jfx1r45uH7F9Sj4oMCQUBfF8ymun5OU47GcZpIc72eiYTLQiBl1RePFv4JlzEieTtKcMTLJYAxAOTHycJLKt+CuDjKInpAk8eJXv6rmLpKW0RHo9ZQHfpxM0+DQUislL649uBpv71/sNQcJJOmQtiNhL9LE4H4yTKTiLT8A7bLsvI9giqkKyvuy5kwzozex1kgCroGQJFFdb/NZiEFaRk/03o92P73ZLMfJNA02ZFphZjmwU1v8Y/vLQVUdpe1Y2IuJpskAzbb/V1TpbjYpN2ZgakBie//d343A1X/NBFUnBXM7g/mJhC8Hnt2lZbTSkYdJeLNZjpNpGhxaagXIc1JUXaRrBkjJaqRD88mOQ+KRnjNMNCNVMl3Ut73omq2Gwxp8TSmu/msmqMSaqpM0g4akcN7euV0A18o/xvXQNGJoud476jO/ZMPRTMfJhLAh89VXX2H8+PHIz8+HyWTCxx9/7LGetPhmzZol1icmJmL48OH44YcfEJFQfJ1ElnYuQcn+dbpesvrn/2HYvDVCTO/Od3aIR3pO5YQMw2gnAZssVX4TNTMSMjBn2Bz8a/S/RE6ZMmHevS+YkJeUx9V/zQV5nal02fVpKz99pcK5Eehe+dDnuxvfCnYMNu/GBPMG/CHlF9wwtIPufZVU2/DzmfcHdpyy+7945Hyr8DFkqqqq0KdPHzzzzDOq6x999FEsWLBArN+6dSvy8vIwatQoVFYGrgcRsqWF1C3V1T01e+1cXS/b8OU2DKhcI3549AOUax+wMcMwWknA1Lrjc+cyH2VOfx/0d1zY+UIMajeIq/9aGypZptLlVIU4XVImcOnrAZU0S/oxUj4VKaivj78D78Q9jKfinsFzDQ/gvj2XieV62ZM+XP04yVOjVXqtuP9z9+wwblFAHpmPPvoIF198sXhOb0uemClTpmDaNKfMfl1dHXJzczFv3jzcfPPNkdGiQEUfgdLKCjrko9higUPlTktLsqx2rDr4OyTbnppLUjkgJZ9JujPrp52vLbHNMFGk9ipXbiU5g6ST1XPQfLXuoGrBuVvmeoR9yRNDEgas9tuCjRqpx1H10SaJ4lEInrzXciOGetoR8lsmZSTSf2+pnyLurf54+6bBIqzpdU12GAQc3Ox9jWrp40hmd5TrzlSEe4uCffv2obCwEKNHj3Yvi4+Px3nnnYcNGzZoGjJk7NCf/IMIN30EugVPLy3D1JwssiQ9jBnxL4cD04+Wuo0Ygjpk0w+RygHpB0c/UEp4FD8qhokmtdeUdsBZfwEyO7sHDXkS8KoDZXj/gPGGkVz918qtBOi7fv+6oIjiyfVjyJtNvezEvxXzPpOrvGJm7JuiOokSe6FHtJTOVWoUScf9VB/PazQpCxg7H1j5dx/6OCbunh0kWs2QISOGIA+MHHq+f/9+zdfNmTMHs2fPRrjrI4ysrsGC4qOYm5mOopjGryHX5sB9R49iVE2Nx/ZS92z5D06vRgLDhCVas9nKI8AXj3jN2C09JgjDPia5my5D5u2f3hZ/cvVerv5rpVYCekTxPrsL6DoGiInzuzv5vZFKpz0a8sLbmMk3leL8xF+wuqarynonFML08oBrXaPkUVryF/26M9w9O7yrlijkJIdCTsplcmbMmCHcUNLfwYMHEbL40RMgY2bFwcN49bRJmHfOPLx6xhQsP3AQo6o9jRgJ+g3RD45+mEY0Ehgm7PA5sEF9xk6Diqx1h1byrhJW7zWANHArJ2iK7yD4ongu42BBd13vIb835uC4rkN46Y8n4a6RXdE2MdZjOXli5P2YArpGfcG6M+HrkaHEXskz065d4wVSXFzs5aWRQ+En+gsLdOgJkDN2QLtBToucMtp1QD/MvNR4w72ZGCZs0DOwabjppdYdJCxJxoxaH7JgaDdFHX69Jk0IlegdzKtLdYWZ5PoxxWira9ffHI3FnSNPw+3nd3HrFJFBRPtSzUU0dI36gHVnwtcj06lTJ2HMrFrljFMT9fX1+PLLLzF06NCo0kewdRiErYVbsaz6ALYmxItkYF/QD7OWkoF3O8NzDBNxGJ6lesrDa7Xu0KPdxLR8KwHDg7mOnkZXDugozKst9u6iWEJLgouWH3ZkYuJKi0gal+sU0aNmQUWTPSmsOxMWHpkTJ07gl19+8Ujw3bFjBzIyMtCxY0dRsfTII4/gtNNOE3/076SkJFx11VWIKH2E9651zfkaf0nO58Dqgddg7kdjGysl2uUi12oVycAUelL+4AqRKX6YjuoGrxb0DBMxBDpLlQ0u8uRdSuylfBh/sHqvvs9W73egCzJI6C8xHagp0/ECmcFEk0VF0vHy3cUebSykBpBULEH3ULldIhk3sxuugY22c3XC1lUN2iRPStP0cZgWNGS++eYbjBgxwv186tSp4nHSpEl4/fXXcd9996Gmpga33XYbysrKMGjQIKxcuRIpKSmIGHpMwLdDnkT+xtnIRal7cREysPTMiXhm79term8qy6aKJkoGlowZ+Q9OyqyXt6DnMmwmopC8mZR7YSQHQTG4yJN39RgyrN6r/7MNaDtltROFilbMCCxE89My4KP/83htTWIePi6/EkcUpdRSA0iqXspHY+IvTQzpniqVXhuqBqVrlKqT5KXiGjiSMmGic/VIjp4b1aXXYakj01yEuo6MJMpkgl0k6VJ+C4WGttq7IqHLfJhjy1VfR2XZuTYblh88LPJoyPUp/8GpahswTCThrgghHDrc9PnAlJ2qM1zqXF3wzrkori9X125yOJBuScWaP6/jHBlfRggJu2kalyangN2YOc4SeWVJtlq1U5ARsqEOuGUqlJgV92HybitLrp+8sq8IK+nWvXl/kvbxuLzoV8Q9i8eH1GFgVj1QVQIkZ6t/RqFSCt9ChL2OTDRAokzkMXH283A2HpMg0S4tI4agm21hTAyus1yJhpouqj84CUpKoxs1d79mIlLt1e/g599NL7SbjpVhahuzt3aTay43+XAJVv1wBGN6nxTc84gUZKHyxk5FchxO78SHN3mXZGsKwwWCySnZ7LB7H6LLmNHShZEaQPrCUDVoz4uBQ3cAG57yWiX3ov9eZ8erq79F77R3kFhTGLyy9eYohQ9DWr38OpKRizIpMcXoa8Ow0dJR/PC0jBji97otKPigANevuB7T1k0Tj/SclEoZJqyhm/GUXcCkz4BLXgHOm+6c9euVh5fYvwEjjx4S4docm2eSKHk+afnlNcVYuvQDbszq7/uQSfTTJ0kFCsuSk7wKFRwVR+B471rYdn0UnDJlgcuAUjFitGQqjECVToarQUc/BFz6hggfySFPjOQZGm3egudiFyJebsQ0tWy9uUrhwxD2yDQjvgTrHFZ9eUDp8ZmgCKxW99as3J/w4p7XvfNsqotF+SlVbrC8OhPWSCqqdGP+dpEzr0KCchQKHvE/+3QloFLO2YjqGmxPiEeJxYJsmw39auvcKtoxVcWsmO0P+qy7j8Pqbc9i7v/eQVFD46RMXqhAxQ3klShfcgcyEKACe2JboOa4p9Ha4yJg03N+X6pXP0Z+P1UVvdNDr4uxKX4onnztDa+wlYeycLDK1puzFD4MYUOmGfHlorRVd4K9IQ2mmHLVxnZU00SiXneNvhCT//2dlyPX5G6O9ylqG7wvZtbGYCIKTQXVUqesvcmPR0aWgCq0m2ob25zIoQHIawISxjkIauFuXRopflh9cC2m7v6X30IF2nXARgxx2SLAZPb87Om70GHI6NWPkTwxZMQ0pQK0uKpBNWzlT1k4IIVfI6XwnXTuM4xhQ6YZkYsyeZsaZtQVjUdi+8Veol2SIqmzWd1JeP5qi0c5oaQ2efXwBrzw81Fd2hjy5ngME1bomH06lk/HptjBYjBRHaBPHoq6pDzEVhV69dtRShvcKZ+ARFAOgryxZlMGcMrHo+aaakKDlHtEOUfzMtOF5ytwc8+VvH3KMG+j0U9Fm/y7lO1NbDnlgtNgtdORO4SCb1abeOSlJQZs0OmZuOr2DBkpW6eKrWDvM4xhQ6YZoR8G3SScVUveHhVbZS9c2/kBrCh80aPjLnli5B135Q3x5DOpFb/9B/jZ/3GwNgYT1uiYfZoqDgm3vjQj9hqgzRbEjHsUpvev1dQSebDhGuSmJWHgyWnAvnXOwUJt5h9AE8NQqZ5UDvs0yTKqR0UTI/n9SqtQgcJ3kufrqCMFGahUNSINJ2/7TDo2CQ/3UzE3wF5n9pj4NdXjEujEVbdnSG95Oxn2378X3H2GOWzINLMbNy0xDteffQo+2nEIx6oaVH9YU+1/8ltxJKlNBqJ5wdoYTFijc1Ypn/mqDdCWnhfh29+fQu6GWV5aImTEUFLmh/1+h+Wp3v7d9mGUgyCvntQ4E0N6VHonRpSDJHlHHmz4M56LfcpLGFQVPRorWhVtqfkwjZmLf3Yfj4uCEEIzGrIb2ysPr3z9m8c6SVk4D8c0DDmX94k8TXoNex3aNaD8Mb37DHPYkGkBN66kXdAp8QS6n9YFXQcUYGDnbPcPK9COu1JzPErsVXPzSnk2tB3DhC06Z5Xyma/WAH1mwSQsz78ADy/9QCT2SkmZ5IkhI+bMjXfqrK4JnxwEX9WTcJ2tESG47AR9VT2ZVmcNk6R/dWuDGU+1fQfx1fLy4/bA6EeA5EzjOUiupGO1/CV6dUtpa6mF7Ohykzx9lPD7VOyNmGOd71rraJrCr95w0RmXh7yRHSzYkGlmN26BeYtTTZKSvWjBz0DNwTxYxs9vslvaV3M8eZ4NN8FjwpoAciJ8DdCkEzOq5x3uUC3lxFA4SXhijJYIh0EOgq/qSQmabNl+/Qqotvk1JqjKi6qTKLFXS1yQStpPqY3HrQ23CiOGtvo+5VzETP0HcHBj8BKnpYq2EAvZSTKz5I0nQ3pgp7Ew7emtkW9lUOFXb7io21hEC2zINKMbl4wY6u+hhLQESF/BFIQYu9Qcj5LvfOXZMEzY4iMnQq11h56B3AI7hph3A5YiwJwL7LcFpjgbBjkI/gTe3JOtr4/pSmi2VJWIEmuqTtISF5xWWoZHGv7ioa4rSptjYjwMDyHkWbjVZ1g9nEN2/9lViL+Pc5V0+/AgBbd9h8lYqCoCYEOmmdy4HtoBikmLWbr8KMYen+qMdzZhdiJvjheONwSG8YtGToSyV46ugVytEokaFhoifAYLrSRUukdNtnyMqTFL3BEOXQnNbXJFaTWVWM/NTEcRGScuyBNDRgyt/xcy3Pe/Zyae6ZVoS4KdahMw8jKHwwQsoJBdMDxIfpKdo7EZJRsyQUaa/fnTDjBJMfY3LwpKWWegeTYMEzYoZrS25Bxc9k4tDtc1JtFDcUvPUyq1aunR6Oq6HJ6DhVr1pNML8wbyTWXGE5pdHoGRFUcwovqwl7igyQEcloX6yGuWnhzvZcRQSDychTz1hOyMbGcIH8nOiMJmlGzIBBlp9mdUVTJcyzoZpkWRzWhpaP3HBKkpq+q81FOp1acejQHCcLAgbwhVcFEo5IzKr1RD3roTmmUeATNMHuKCWqE++WDuU4fGVdc0b8s84WUOZa+y3p5MerbzECpMjsVAyx5Yqop9e+olw37fOmD/eudlTd8Tae9EGWzINJMb95QTFL80SniVdTJMKA3QSsFIL90Qv3o0fjj9ImDgTT5DwMFSzm0OhB5V92xUP3oLUOcd8jaU0OzyCNR/dq9HFZJWqE8+mPvVoQkTIU/fgqcaHkE/VU9SvpJF7s335an/8VPg87sby7HXzQ9bwcamwIZMkKGb1nP9fkefDR+IzHW19gNyqEDRq+9LmJR1MkwooCUY6WVANLXCiAYGH7/JYCnnNisHNiClvtg7JyaQhOYeExDTdSxum/esRym75ImRZCe6JlVhoCkFsJ8tDEDdOjQ6twtVwVNo9G6SG7u/Ha3GwtU/+ywO0fTUr/yHatdtkLEeZZ59NmSCjd2GM3+YCwd1mvez6eqkRO9kOanpWhiUdTJMqKAmGBn0CqPk7BZRzm1O9v66F12DmNBMVUgTLrpcnCMhnb+H7IQVwKIn3J6C7Ix2ESPkacgjqGHsEjGw4pHYV8SY4T35VfHU7/pY3Yhx44gqz756vSITOC73tR4jhsoXiywW1aZrq2ub4AJnGEa7bNWQO0LGRzc7k4UNluEStJ62a0no/TbuLcUnOw6JR3peZEvR9VqyPbYmxGPZgInYWrxd5LX4G8xp8IbMs5CnLHZweRb6lR5CWnya5v4oRyYvKS9shDzp/NdPOx9v3zQYT17ZVzzSczUjhgw+pRFDn9em+MnINFX68ODL8pXou1g21f+BVbi2jwLYIxNsdHhS6JZAnhhxW1Ncue6ma78txYizJod0shvDhBU+y1Z1UFmo6rIPtnJuMFCb+f8pcTvus7/q146jSdacrCwUW0zAr++JP39l0e7w3t4S9P3gLphq1d7G6VlYu/ZvKE+x+MyRGXXyKJEjIxkzeqUlhC5NK8hQ+PMIahm7muEkX+OLaFFQqn/7KIANmWCjw31NOTHycJJq07XqopBPdmOYsEOrbLUJyfitWoarM8xFA+Zjdt8DJjmMyIi5OyfbywrRUxYtBvOYn4Ba7cHTBgfmJvo3IN/88U3xJzw3DqC8vty9TsuoCmVdGjVj15fWmM/xxYhx0kY2HpEnp6lifCEKh5aMQBcClbrtXOJ8VHO36nBfU2JvJCS7MUzYGjNTdgGTPgP+9DKQZMRLInPxN0MZblNRm/nTgHl/7CIRKlreJkk8qgWKDiEDMzI7qt66pFJpKov2FWbyN8j6m8QpKa8r9zBi5EYVGS5KXRplNZTatq2BmhEraY3p7ghOfalofNGb65UkaxpJIdGFvYA3LgQ+uMH5SM9VQqXhCBsyetF7IUjuax9ua6pOipRkN4YJaz0aaqx3IXkqRJql/tfLBmypDFfr1bS8nY4y3Oaa+XdPXYG/dEzAjfm5mJaThevb5aKgQ77wvsi5J+kS1MfW6CqL1sTPIKt3EucLpVHlT5dGvm1roWbEGtYakwQY3ZNlP4x73Lm9JAKp9EBK1VARYMywIaOHIF8IUtM1qS9JuCe7MUxEhJtSDVQVyQZsqQyXUBozvspwDXl6db5GOfOPSdmFg/lfahcVyIyZUe2Lmu4p9uORzrbZEQzkRpURXZrWQs3YlXdr9+tZkedluSfLPgzvoXcAPS/2IwLpWkah0lY08oIBGzL+MHohuLfXhm4pVGJNKI0Z6dLkrtUM0wrhpmuXAolt/bv4OwxyGxK2X79EZsZ+/N/YcmRlH6SbgHtrquTxWXodiMvfx2s8Z/52xOd+6jps76ICYl5mujvM1Of3FWiyp9g9yIo3Vaw0OSdxsalishYMyKgKB10aNWOXNHcOOzLcasiaRszUH731YNzGt8IzQ9tf+gYw+iGdIpDeodJwhJN9/WHkQiBXtU710POra9WbriXlcddqhmkNaBA+9Txg/NOuyiaoy5z1ugR4qo/4nXtpQWUBHfOzMabdzRjRYaSXMJ9cDK172Rfo+uVkZ981LQE0ZbfkqlJgyXXeEyshgnYNBl62CO3S2gj9GnPSPphjPfNLvIoKYmKwLT4eA+rq3J5i8tbIO1o3nr1JJM/69RT76ANkGTMX05OTRN4K7U8tHGQEI+F32ra1qprUNGdIOHB2w7V4IW6hqzFD42dBz4mfBzyILuZYMfn1Qk837RNFUVHdxIaMP4xeCDq3v7v+Fkw8dzBWZNVju60SJam5yE523iS45JphWhFfDfnIiNnwtBhqJC0o5VBcVl+Cd/b/EwM7ZcJiHqlaEk0JuOvj74fDJA1ZKtVRn97pfQwmcqJrD/6Wz6Zg5oXrcOu/v4M5plLX6VLeiknmKaZzIk+x0pgho+Pijrfpc+T7GGTpE6HqJ2WFkRGURhX9mxJ71Qwjaduy2jIUfFDQqlVN3irUg2Gv7QfLiuke3/MRR4az1cOKtmi3aY22OrS/btptdCYGN1UsspUxORwaiRphQkVFBdLS0lBeXo7U1NTgvwG5j8l16w+qgKALSuf2V9bfj/0p/fDYpX1wtKou5PqyMEzUoyxXpXCSyxND4RhKmBW5JxoqZpTntvyS5WJioiyJHmzejXfiHm6ej7jvVfgurh/m7f4FO7OX+d381SNFHo0f1RTH7Q1pqCsaD2tlr6C1XZB7Rw5UHMCz3z2ry0sjhaXkpeBS1RIhf7207XU9r8PrP7zutW+1fbUKdhv+/d7b2Pz9j16tHpzHicDUoe02Z9iRvHxaHaHIQJ+ys1VKsYM1frMhE+wLwbW9o+KIt8vYpdVAjdWG1T3pcaGGZF8WhmEakU1SqISZqn/88WrBq+iX0x/D5q3xqCaaYN6Ap+KeadZPl4yt0R07OIXtNEi32XBfaRlypT5vKj3g3q6dgHVVdN7O+5W0t2C3XVDTgWkb3xY015aXYJOBSDmEenRkaNt7B9yLR7c+qun9kTw2ktHZGiz7/jBue+tbn9vQ+ECKwYYnu7tdxSpaodJW7MkULEOGQ0tNUgM1eZbFKbYno0V+zWm1uA/VviwMw8iQhY2VVUBaFFUVqZZE665YaQJ0hDOOlmJqTqbwGqlNw8osFszIyfLs81ZdI14reWkW1Xdx7i9pL0wxlXBYU2Cv7iTCZBQmCZYXmQyTER1GeOWwEHryWrReH+rdtilv6v5PdvndLmB16B4+QqU0dkVAY0k2ZJrjQugxAT+f9yxSvrgf+Tjmt8W9IjIe9BsEwzBBQJZHUGbRV/BZVlcGW723GJpUsZIHvYJogTGyuhoLioG5WZko8uGZkZdkUxECGTOS93hbshXJufM8Eocp1FRSNB5b9vUNatsFMlDUjAm9Boba60O9qomMk2NVDc2rDt1DI2dJ8jSGudovGzKBXgjUCZfSi6qPOi8ExQXQ5byrcO7GbHQ48Z0QPlKLe4ZKXxaGYXTg0kihsHG6Tj2U9Ph0ZMZ7i6FJFSvUZ6fBAexIdIZxshUhnmAZMyMOVGP7RQtQlJorwixkYClx93nLTMfwakpIduCO+PMRn/+W17ammHIktF+MtQdPwZDOVyCU0VvZ1FoCpEaMkyapQ5sVicEUclKdnM8LOy8NGzKBXAh0AXx8i88LgLwp/5jQG7cudlraRjOqW6ovC8MwOpGFjbOt+gTEckUlolMMjULH8vsAeWYvj78MpbkbcTSmcYKTa3NgekUtRh4/GsCdQx0yjEyHbDhqT1A1YpQl2ZvT2uGNksvwY4c1Ts1jhTOHntM8bvmRlzDNfmmr5JboLaWm5XqqmlpLgFSvcZKZHOdWh5aX8ecEUijizpvxUfofRsYMC+I1o8qvsr29EVqiLwvDMAbpMQFbBy5Efm2yyCkRo7kKtDgtVhpc1ZV/SXV3T/5mlCjCVMUWM6amJ7pUd71F5WyuZONlydp9k9R4bEM5Hl6xWde2ZeMfxbeZ+SKcpFGUJZaX1Re3imIuJfZSKfX1K67HtHXTxCM9V+upRMYNlViLY1Z8ntLz1hQglVR//fHQRb3EtUQVcJQ8PvHlTbjznR3ikZ7Tcl1EoNovGzJGCOACIGOGMs3fvmkwnryyL/594yDkpcaHRF8WhmGMY+s2HufVPYW4ogucv1jF7UCybSZ2/qt7cPSe1DhVd9W8HU6vgQnzOnSGTdE2YXVWPgq69hIVU776JsmhXJfDjkwR2qZEXT3ktsnDnwakhmRuSSANIikRmEqsc5JyPJbT89YuvZYMXV/+lJvP7YSxZ7Rzl/Erk8cLXYUiuoyZCFT7ZUPGCAFeAKK9fedMXNS3Pc7ukoVZE3oG3peFYZhWhSYZuWlJ+LHiD6g5dDXs1jSP9Q5rGhLL/oJbBlzssVw+qbnzQoszedbko5Kmvhzbr3zNqVF1yStYPe4hTE2JQVFDhce2xTExmJqbrerBUVZK2qo7iURdLfUweZ+3kV1PC7nckqY2iFTKpoWKjJpk6Co9MxnJsXjuqjMxY2wP1c7mEg7XI62n7XwSgWq/nCPjA2UcclBVoT7Lz88FoJSqlqDZGuvIMExoI82gaQZsq+yFqsoesCTtE6XJsKYIY+Hxq/urTkakSU0pDT17/b9XSe0x4NSxzgH8gwKNAdxpgMzr0AUjjpTCIptseVdKmoWwHSXq0hgu9wYpwyyhmFsSaCm15MVRnkdJTYlY3tpeGXXVX8/cF7Uy/oAKRdpEntovGzIayOXEJcamHMZzQboA/F20DMOELsrJiK26c6Oo5dW+RS3FvWXFQdGXSa+3Q9cA7vLgDKhrwDc//ChyYtQqJUmdt/bQ1c7QlqykmowSudCclFui1heptXJLAiml9ufFEUbglnlCg6a128NIhm5TCkCK/W0ndSj3J/IqlWeHAWzIqKCUE5dYUXkqDsdnoJ2pTFW11+gF4OuiZRgmtFGbjJx1cjq27S/DJzsOqU5OGu8t7ZGclibKmNWSaZXeDt0DuMuD02DvgU3rN2luR8aMtbIHZl2WiJz0es2qHym3RKmYqzR6QrmUOtQF8YJdAJLjbzujIq9hABsyCnzFIW0w40HSflDpVhquFwDDMIEjn4yQkXLe/LUeXlx52xHPe4v+EE8gA7hUCaMs+W58DwplJ+GaM/1L3msp5raG9yKQcFeoCuIZLaHW950m6CsUiTC1XzZkFPiLQy63D8Qt9VPwVNt3EF9dGPYXAMMwzefFlbcdSUuM87i3aIV42sZl4/4h05AWn4Zlvy4ThkOfrD6GBnB5Ho/GnNtQUYGW4m5LE0i4S68RWFpb6v68m9tQU0td8NdrL9jfKXx0KA83uGmkAnIJU22+P568ojcuarvf5wXgy+LWK+bEMExoQ79zZVNItZnyfWO64653lfcWOyxJv4o+RmJf1afiunOysaroRQ/hOjJSxnYaKzo4E2oDuFrCaiADZjig1SBSLdxF91rSmNEyAgmzyQy7w+7xeZPB1ByhMy2jV28zzkj6Tiu4+3VwPwiJjXtLhcCQL8yw49PxZvRMrdE0YnxdbDEpP6jGnJvrh8MwTPOh555B/GPc6Xjo8x89BPHic5fCHNtYTm23xcFsqVd9PRks1/W8Dsv2LdM1gEs0WQU2RPE3GZSvP1B5AM/tcJZqaBkzcnwZhy1h9Prrch0p32kFd79uHvzFIceYt2B23JvIXVWq2Z5AqyU77fP2TxYh8aTFXuskMadQKANkGEY/eqtJMpLj3PcWS8oukR+jxGxWN2KkAfg/+/6DZX9chu+OfqfbmxupRQW+wl1qHpu0uDRhKZTXNYbxtGiuaqZglVBH6ncaKCyIp0BLTlwyYp6LXYgcyIwYRXuCZd8fwe1vexsxhMOl5qlmIekRc2IYJnyrSfLSEl33Fjvi8z4Uy7wqlvxMqp3VNTtgrToVDRV9xCPfxvUp/5bXlwsj5uLOF+PPp//Z7/clr2YKFkEroWY84GRfnYJ1FE4iT4yQFNeQpKr59F7cXvaYZodrEs0Sap5hXgbIMExg1SQ0UZo6wYKX/lcd8Ed4+3tf4GhhSdjnRzQHvjRjJD7e+7FXzyVfrD2wNmj346CVUDMesEdGA2WPJMqJyUWpj8vfgcSaQgw079HcQih/hmAZIMMwxgfMrYVbRZXL9uJv8I8Lu+lvO5KoQ9LXB2UVCYH32Ylw/GnGSOjJk5H47NfPguYll4xe7rUXXNgj4wOPOOTOjbo+0Bwc11ynt2FbS/YuYRjGGGr5F5Ssf9u4m/Hh+gz/bUea0N7H4TDBZKnyXOYymMiDTAJ94Zj0GSyaYxJI1WPB8pIHvYSaEbAhoxedfSeK0VaEocgzQ0YNPZdkwqWGbVpqnnRV5yY7G7YxDBN6aPXsoWT9N399CI9NfBwptsE+q0kGthuIl3a+FOAROJDQ/i3UHjILHRrDfXYinOaaBAbTQOJee8GHDRm9+OlPQTnuRxwZaIsKrI+/A/mmY+51hx0ZmN1wrWjcpqXm6dwH0Cd9OOvJMEwIoqdnz/ytj2L5Jct9/ob75/YXFTSUfGoUumfQvYOKBqjFgDI7INqTRP0p/4aKgRQSvfbstogQwyM4R0b3J+XqT+EjEv5fyzl4LvYp5KHRiCHo+fOxC1Fg3iJmUfWl52q+zcpD74hZH8MwoYWRnj2+ICNn1tBZAR8HGTNUNEDFA0qiPUlUUv4NFmSckk5Pc3jJpdSFi/q2F48tasTsXgos7AW8cSHwwQ3OR3pOy8MQNmSMIPWnSFVUB6Tmw3TZ67g03imKpbwepeczY9+EGVbEpn2nunvJQzNr4yxsPrKZy7AZJoQIZs8e0op6YvgTyEnM8Viem5irqzRYWTxAt452evvsRDhSo0vyzPiDFH21aK0O383O7qVOuRB5jyWFjEi4waElo2j1p9i/QVQtaaWjkzGTj1L0TP4Kv/kowSZI6+DGlTey2i/DhBCBdF4OpBkjPf/3j//2+3qpeICTRLU/25e/fxnPfvesppEy/9z5SE9IFyXWVJ2kbAvRGh2+mz2ctHyaRsa5K218+XTnGBdGxhsbMoFAX3CnczyXkVGjg6SYo7rfhtV+GSZ0CKTzciDqtH7zPByA3Zomigc0K6MY8dne0vcWdEnvolplJjdS6Du4u//dEdv/zuZqaWD79SsMU3piPHAAFYecE3XlGBfCsCETpEQoW3I2tifEo8RiQbbNhn61dVDbelyfvthdok8psrlkshmGaZnOy83yPibgtt5346T+/cK6z05LoeX5Un5PodLhuynYVHowrdpd6BZ3nWD+BsPidOxI58Q8VGBDRg2KEZL7TW65KvopeelKbJuLonaNMdlcqxXTS8swsrrGtcQk9vHn0ZOx6KPPdYk2Eaz2yzChl3/hb4YfLu8TLUSCkeKP5SqNitsmxeJ4dYP7OcmBBFNuJFQwORxUzBe+BLv7tTsRSqvJOiX7yowZLV0JUSMJ4PHioxhdXevxWuk1YjOdJYLzzpmHsaeODfy8GIZpsc7L4fY+THh/B8t3HREiezSaaOmYwbWO5EGoklbTiZeUBUz9EYjR47oJjfGbDRllOIlK0DRjiE6vCqbsFGEmusALPijw6V0xOxyYf8KO0efP9TKAlLMtX7xa8GrEzygYhmHCQcWZQn+h4hWz2R0YNm+N8MSQxMfM2EWaOmYEbUNyIISmMeMjAhGKhgyXX8uhnBi9iVA6+3rYTSbcnWLB6uQk9zIygNLi0zCl3xTcc9Y9SI1NbRUdA4ZhmGjvlUWPar2UtLpoS0UYoaL3tWXfMbcRQwaKLx0zggyaWxumoBA+SvXDrBSbc2QCSXBybWdEtlpK2F17cK2XhU9GDdGcCYQMwzCMPi+LHhXnUCnCWL27UISMyBOjpWNmdzh1zFbV9RdhJjJm/lvXD5vjJyPDVKmiGhJepdjskQkkwcm1nRHZalL8fHnny6oWfkVdhXhMjfP0zNCPixL+QsWFyTAME87o9bIES8W5JcJKH+04JHJiKJxk9qVjZioV20n0N/+MTFUjRj0CEcqwR8ZAPyV3jgxtJ9N70Jvnsnj3Yp8WfkJMAh4f/jhKa0pDNqmMYRgmHDHiZQmminNzh5WOVTUgx3xc1/aUAEyYZP+OhFJs9sgY6KdEl/9PZ/4dn3xfiI17S8XHZ6Svh68mcfRDIoOIJLOpOokSe9mIYRiGCQ56vSzfFH2j29teWlvqM8+mqd4WGmc+2XFIPNJzJVKT0GKdZdXSdiSiePXIARFTis0eGa1+SgodmZrEXJH5/c4KuhB2iGXU22Tm+J54/LzHce9X98LusKt+yGQSpcYko9xaFfIWPsMwLU84lPiGO3rvrXd/cTceGPKA3y7aNOl8dOujzVLNpKYJ005FwVlqErrF3l1UJ2mVVZO/qT4pDxMvugJ3piY7RRRhB3boj0CEMlx+rUPZd0tJDCautMCmcGBJ18vzV/eDuc1O3P3l3WofsHi8rawcz2b4t5q5zJphootwKPGNBMhrcv2K63VtS2Gm63peh9d/eF233pdUnNHUvEa5Jozn/hvHG8mYkUqvC8trMVqjrNruOjaTQgPNUzfNeZZe76b2miDC5dct1E/J1vMS3Lk5xcuIkX/tZDlf0HGU6Gar7Liaa7NhQfFR3FReIdR+JcNGCZdZM0z0ES4lvpGAlNMoGRz++M++/+Cx8x5DTlKOro7ZkrFDeTaBhpnIMKHxRKulI0HrpTATtaaYOb6H+PdKjbLqusQ8dSNGHoFIVfTpIk9MMxsxwYQ9Mn6g2OTElzf5/SDfvmkwhnTOhM1aj+3P9UVxXRlyFD2XViclYmpOlvi3w2QKuiXPMEz44E9QU2pCufyS5RxmChKaSuw+PORSR3IKTVFOjDycFGwBU6PjjVooyuxS9u2aVIULh/bFwOHj/ZdPG+wtGGoeGc6R8YOUTKV3O8vBzRhw7JDqNtR3ibwzczPTURTT+NFz/xSGiT6MlPiyqjeC2sNq5oaZqKh3yl74gowXeZ8mSuzVQ6C5jkbHG4kxvdphVI88WcPIocaaiboiEOFKSBgyzz33HObPn48jR46gZ8+eWLhwIc45JzQ+VCmZSu923/24B318bEfGzIjqGmwf/Q+U5PXgxD6GiVLCpcQ3Eo2ZNrFtcNOqm/xuq6xe0lvNZERjrCnjjRyL2eThpQkareStCStD5t1338WUKVOEMXP22WfjxRdfxB/+8Afs3r0bHTt2bO3DE1YtZYtTMpVGXrcoZaPtKG754rfVeM7PPukSGNBuUFhbwAzDNI3mHhQZbcjD4qsqSQrrKVvDSHk2Rl/XHONNi7B7qVcFb0v1YQorHZkFCxbghhtuwI033ojTTz9deGM6dOiA559/HqGAPJnKW1nGCa2n7citt7zyVFEGp1LyL6DldUntwqKkjWGY1ks+1SoA0NMniPENhYskDTDl5++rNUygr2uO8aZJ2G3AvnXAziXOR7VrSKpoUvYfDME+TK1qyNTX12Pbtm0YPXq0x3J6vmGDuixyXV2dSBCS/zU3FH+kkjeyhOXQc3kpHMUmqY8F6c0QSmNGev5dr+kh55pjGKZlCWRQpGRVShCmMuJp66aJR3rO1U2B58soq5L8tYYJ9HXBHm8CZvdSYGEv4I0LgQ9ucD7Sc7lhQoYNeWJ81U9RH6YQMaJbtWrp8OHDaN++Pb7++msMHdrooXjkkUfwxhtv4KeffvJ6zaxZszB79myv5U3NetYDhY4ak6kScNbJ6di2v8z93O5w4M//2iy2VW+nnonZDdfguhvuaJ5YJsMwEaEjQ54YMmLkg6JWxQ1XPbaOGGFzixgqxxtDybtauHVjNFRqpJJr8tKQgeOPSZ81KUUioqqWTLJSZIJsK+UyiRkzZmDq1KkeHwSFoloCeTIVlbudN3+th/JiXmo82ibFory6ASvs/fFfSwZOi/0JWVYb6mtOxTf2HshJS2q5+CbDMCEPGSvU38fXoBhO3ZjDDXlVUku8Tv/+g5y8a/fnZZF1u9bbXylE+jC1qiGTlZUFi8WCwsJCj+XFxcXIzVXv7xAfHy/+WpPlO3/H62+/jQE4jmJzWyEPTSGlooo6cTnEpOxCfO5SmGMr8Dsg/uwNu2AqovjmtU23qhmGiSj8DYpcqs00mf0bvPNdtLpd6+2vFCJ9mFrVkImLi8NZZ52FVatW4Y9//KN7OT2/6KKLEIrYfvgEZ35wF8bEUdNIJ5TcS3kxK+wDhRGT2H6x1+vMMRVIPGkxYlLOoq4ZLXzUDMOEM1yq3XSivp/VCQNelp5/dFYnhUkfplYPLVGY6JprrkH//v0xZMgQvPTSSzhw4ABuueUWhBy7l8L8/iRkU1qRzKlCjbqox8UtDXfi67wVTiedRsr57A2z2f3LMIwhuFS7aXA/KxjzslB4kkqsRT6NSb0P05i5IVO00url11dccYUouX7wwQfRt29ffPXVV1i2bBlOPvlkhBSy+KIyMiQ9vyjlLZhjqr2NGBnH64+LNvEMwzDNXarNcD8rN+Q9IS+KZq8p8rK0b/SyhFEfJu61pBcdWdxPt03DS+lpfnf1f73/D3/t91fdb80wDCNVLRHypF+uWgpeP6uIDz/tDqDbdTMq+0ZU1VJYEMzsbM71ZRjGIJJ+ibJUm3u1IShJ0uV15aqfLWn9+NOGCRsDqIfLy6Kq1jtX3csSBn2Y2JAJYnxxQG0tXoJ/j8yA3OYr2WMYJrpLtRnjSdL/3f9fvLXnLa/ydmpFQF4wX0J3YZd/02OCs8Q6xPsnGYFDS3oh9xqpH2pmcQP1DhMGdTwVDZYGzTyZtvFt8cXlX/CNh2EYppmhFg6kfuwPCjGpafSohZ/ksEhhaISWWj3ZN2yQsrg1zRggzuTAo0cPO3O8NTaaOWQmGzEMwzAhkCQtoWXEKMNPcvyJFBIkUsi9sJofNmSMuuQufR0waX9sI6trsKCoBPFWzz4Z9GN6/LzHkRafxs3eGIZhWrifVbDDVEbyb4LZtmDj3lJ8suOQeKTnDOfIGCc5EyaHXXM1hZRG1dSg7++F2HvT+zhWd0zEsctqy/Do1kfDJ47KMEyrEDaJo2GWJP3gxgdRVlcWNC2ftQfWBjVPxx/UFmfW0t0orJC3xUnArAk9mt5IMszhZF+D2CsLdbmxslGB7PoG4NSxIo56z5f3BJRIxjBM9BB2iaNhAn12tdZazFg/w/BrpRwZuUYPGZuf/fpZUMUM/Rkxtyz29uyQUXPL4u14IRhdscMYDi0Z5MfKJP0bnyjiOCrDMLqQEkeV4QppwkPrmcDJTTbeF0jKraFO5HKvGHnM9Hh3MhIymixSSOGj6R/u9LnNjA93RnWYiQ0Zg/yS1BuljhR9G7fJbZU4KsMw4QUnjoZG4q9Zkf9I26t5zPWGi8Z1GtfksOCmX0txvLrB5zZl1Q1iu2iFQ0sGyUlNxv0N1+O52CfFc7UyazKMG5LbIf7koSj5bUWLxlEZhgk/mtLdWk9Oja9toiUnR0r8Je+WstxaMm7mnzsf6Qnpfj+n0lp9RsOIjiOafNyU1Kt3u7O7ZLWYKm8owYaMQQZ2ysDUlPPw4om9uDnmM1UjhoybmHHzxAXDzd4Yhmmu7tZ6cmp8bUNEU05OoOrIap8heW/sPgo/gtf7yhHYdruXaij4zgupPknBgAXxAky8unXxdowxb8JDsa8hy1TpXnfYkYmioTNxZsEkj14fFOdW0xvwJbbEMEx4o9fboVe47dWCV90eGT1ibITWNr4E4KTXR6IxY9QLpfU5a9HUz49yXbbsO4biylrkpCTAarXjmte2+H3dv28YhLNPy1L0VFIes4+eSmEsiMeGTBOMmdmf7kZReTUGmvcgB8dhTc7BhAmXYEzvkzy25WZvDBN9GKlAMjrh0dMMMScpBw6HA8U1xYaPnSdYnt+Lr7Cf0jNDnhhf3h0948qRcs8S64raBlTX2zRf1zYpFtvuHwWL2SRToT+s+e0Kz8yUna0eZuKmka0MlbqN6pHnspz7CcuZwk7iQlLAzd4YJrrQmsVrSS7oyd+QV87oyanxtd4fvnJyoskr4+9zJsiIuW/AfchMyGxSjpHk6VeasUUVtX59QXP/1Ltx7KGcGE0jhnAAFYec24V4M0i9cI5ME6ALZ0jnTF3bcrM3hokO/FUgkWFC0vXU/FE+4BmZ8BRVBW6kGCFSixD0esv0nj8ZMWNPHRvw8VA4iTwxagYLLTO5vC5xFhOKKuvd6/JS4zFrQk9PDRlK7NWD3u3CADZkWhC6aUXq7IZhmKZXIOmZ8NAgTCrhLUEwxNzC2VvWUsUa5NmXh5OUOFwl1v++cRDMJpM7f0Y1CtBGp16O3u3CADZkQoxoKYVkmEgl0AokPRMevYmn8hyZkpoS3YmqvtRso9FbJmnP+MtdaurnRIaJHlb8UIg/9GqHC8/IV01jEFCJNeXAVBzRqHhy5cjQdhECGzIhBMuTM0z401yzeF+DsBwpp0Yqr9bKu5Ge68nJiWZv2aWnXYpnv3vWa9tgfk7kXdHDoo37xV+7tATMHK/RY8lscZZYi6olOkbl9eIA+jmraiMFVvYNEVienGGiQ0GWlgeiMaIn8ZQgQTcpPCLl3ZB3Rg4d3xPDnxB/ausitfTaiLeM7slUsaRmxAT7c6IQERkn2prDnhSW14rEYEoQVoVKq6nEOlWj/9IXjzgrm6hMOwLg8mujNINSop5SStaaYZjwoTkkF5b9ugzT1k3zu92cYXNwYecLPZaxsq8xvZ7JfSfjuR3PaXq/aP1NvW9qkidGqRdTVlWPyW85W9XoCQTSlZSXloD1087XDjPRePXVY07DRXUPAC57HUjKbBX1Xy6/bg20lBL7XQdkdjZ8EUg3l02HNwWcHMgwTOihtwJJOZhpSTgYCUWpNUf0lXcTTUUIenJechJzsOTnJT4FAz/4+QNhyASKml4MeWT+79xOWPrdEZ+JvxJ0dLTdln3HfFfPbn/dxx4ALPkLIFcoDkP1X86R0YuWUiIZNXJrV+MiUM6IymrLROWBEa2HSC2FZJhIxF8FktZgppX70NTEUyNGU6RCnz1pvtz95d1e6yRv2aVd1XNigjWx1NKLoXDRS1/tw7NXnYn05Hj8Z9cRkQ/TpETh/f40ZeiEFG0WKEmYxroQUf/VAxsyeiD3HHli9Dj8VC4CtSTeQIjEUkiGiWS0vB2+BjNa/vzV/byMGaOiecr3M2I0RSq+Stclb1m9rVGnJdgTSz16MQ99/qMIF9kdDl2GTI6vROGAtGJcR7J8OtB9XKur/+qBk331oMeqdeO6ROkisNs0k3iN0ja+bcSVQjJMNOJvMCNoPW2nxFfyrlbejWQ0KcMVfhNGIwx/9+J7B9wrPr/m1I7RoxdD659Z8z/c/d4On/syuYzRgZ0ymkErRqb+GwawR0YPhq1a50Vg+2095m7zXy6pd5cMw4QvUnh5w2/7UNxQCKCT6lzSX+6DEZVwPR4AWk/tVsIxzKRXd8tf6Tp5tOZvnY8LOl7QrNoxevVinlj9P5/rpW+KPGoWX9+bX02ZyFD/ZUNGDwFatdsLtzbZEyNxvP44J/syTJiiDC8nnQzYG9JQVzQe1spehgc9vQm6ej0AfhNGw1x3y6h+TKAhvGDpxfgjT29Y0OxPUyYy1H85tKQHyarVXeXvpMQS3I+Xk30ZJnJCGqaYciS0X4yYlF3NNujp9QDo3S5cdbeMqi0HEsJrDr0YLR67tI+6EWO3AfvWATuXOB/puZamjMnX+ETqv+3DRv2XPTJ6MGzVOiWgszsMBfa8hmDByb4ME174CmmYTIDDAcTnfgprZQ/3vFLSB1HmPgRSdaRmDJlhx0DzHuTgOIqQim0JCfittgpbCzuFRUsU+kznbJ5jqClnIHkvzdHol74v8qRQbpJyJDHiLzlaVadfHmSMq4qWEnflGmhVpcCS61wbKo8EwJi5YZHoS7AhoxfJqlVeKF40XgT98gb4jLVGe98Thon0fmj+QhpkzJhiy2FJ2gdbdWev3AfpvVb//D98uLUCJSXt3QaPnqojyQNAib10Byowb8HM2EXINx3D6qREzM1MR2JMDP71E8SfVmgmlD7zjYc3orim2FB5dKB5L82hsUPfF1WlKavIyHi9ckBHPLH6Z7/78DJQd2vJgyiqaDud47nevEjD+JkbNqXXBBsyRlBataV7gW2vAZVHVC8CurVpxVr1Esl9Txgm0vuh6Q1pmGIqxWNaUizm/qm3GOy83isLSE5rzKvxVaqt5gEYY96C52IXijsKGTFTc7K87khqHaBbm0DlK+SffVNK15sD+r4owVrpYSPe2XrAbXgqUfXW2X3Jg/gppVbz1LSgsm+w4BYFLdCyQO2HSL1WqNyP+qL4Esmj7eRKoAzDtGZexl2io7RwpbgwuZ4vGP6E1+9UryR+9f6b3B4ZMkxiUn5Q7XJNb0XUHrpaGDO6ZOqpBHvn7xj8wWCkOSphNwEFHfJRZLF4nIec3KQ8rLhkucfAbsQTFShqwqH3fHlPQJPAVwte9fKmaN2LQ+keK5XLE2pnfdfI03D7+ac1ft/71gFveLakUGXSZ94emVYmWC0K2JAJwTLB5r5ZMAwTQD+0d85FUX256uBPxkxufFssv+JLr8Gf+qhphTTIMHFY01D1C82ozcIwyU2LQ5su8zQ9EMrXEG/fNNh31dEX89wK5FsT4nF9O//VKLd0nY/JQ8YE5IkKBLX3MJvMsCuVZ3XQNq4tvrjii7C9x6oJGMrxCCvuXAJ8cIP/nV7yCtD7UoQS3GspxFFLzNMTa42mvicMEy4IKYWGCk0PhsNkQmF9udhuQP5gXSENybtCoSLJIKFFJQ0/ospAXo3fqiPyGm9+zv20hDwxOli4dhs6p/TR9A4FMwwlVSEp3yMQI0ZgCu97rBR6embNL6o5Mx5hxTa5EVVKHQicI9PM1rRUIdA1qQoXDu2LgcPHu0NP3PuEYVofrRk6/T43/VqCLYXf4FDJx7r2VXJwAyAzZHw1kCSvipqOjJQv4w/5dj5LtSn0XXPc/TTbZtO1f4c1BbM+3SW8Q0YqhIJZhRQox+siQ3eL8mXgT8zw3vNg8Sl656yiDZdS6kBgQybIyHuoyCsEYAXwFVCzNQ+J4+djuX0A9z5hmNZAlte2uvYw5v621CtkckniCHzz02/YnvY9rLHVunedbVP3IEilvG9+uxYPr9gsjARbtYayrzVF13vRdlql2r7UWfvV1iHXakWxxSI8SVqhK2t1J5Qk+fYONbWBIvHyzpd9ViFFq+7Wpl9L9YkZ7i/HEJ/yIA5g9CNhl8BrBDZkgohcDpyMmOdjF3ptE19TCMd71+Lj+jtxxD5Q1V347J/7IDv7SEjHcBkmLJFpbXhU7sgG9KKqQjxX9TbgTjmRDfaKRF+PHBmbTUguaEG/4WvOvAAvrjShsFp9gKI9Z8eejjY+SoUlQ8MuDCENmXp5EYLCkBHVlKVl4tzpuB3KxGUA3Yu74xvK2dHpHQrUaKCQ0rM7tDtNt7buVmvl09CEePoHOz00f4rRFlvs3WFXGL/FFFbs60ceZOUMwGwOq5JqI7AhE0QkOXC6+MgTQyjvL3QJ2uHAA7FvYmVdf4+Lkm4hpPI5bescwFLuXp6TmIMZg2aETFY9w4QlMq0NCq6QhorSiPFQqvO1TmXwn1ZjguWUYU0SRCNmje+FmBT/eTV5aUnqOjJqwmiKdxtZXYMFxUfFZ1AU0zgMkDF279EyjKx7H7ea22O1NbPZjAYppBRsgqW71RIJzr68+qPJox/v8ui7OOzIwOyGa7FCNgnOkcKKZKRQTtH7k7x3KvRkrgEG3wZ0GxuWJda+4BYFQURKuCMLmi4+rWpI+tDzTaViOzlkxJBkucNc7rnfmmLc9cVdXrLbDMPoRKG1sT0h3jmAayTvOjNqfayTQYP/guJSjDxfnxKqJIhGISE59FzShNGSyM+Iz8FVp9yPN6+8UZRcqxoxNGB5zcpVOmlX12D5wcN49UgR5hUfFY/0fHRNjVg/M/ZN5MZ0FYO3pLXi9VHAJMqXAzEayNOhN6SkfP+28W19btdUTRijLRCC7dUf7fLo56HRiCHoOS3/q+VDTDBvwNiUXzDw5LTGa3zFDI09u77/Tc85S7UX9nJeKxECe2SCiGQZkxtQ1/Ye29kRn/eh+JfW/XP2htlNSqpjmKiFwiyywV1v5Y4vhlVV4/qKSvSLy4LlwhcNue21BNHkISLDEvk0kH16h+EBYECtt9w9HUY+SrFwcC0qOvsWkru442347PtC3W0TAglHDc0firPbn430+HTkJju9LWsPrlX1mDRVE8ZXW4lgJThrQddDUXm18MSoevRdDsG7Y5c4FzQAeOoFZxuCxHQ/qvM+FH/DHDZkgogkB15cqT5bUEIxTwlL0l6YY6r9dsD+pugbDGo3qMnHyjBRhSJPRG/lji/WJyfhkgF3wnLW5IDc9DTg++s4bahU+KvHgJoyBJOB2VZAo+oqLTYLtUUXYv5HcQB2NOqbXNgNY9rs86sUayQc9fXhr8WfFNqhz6U5eiEF0ik7mJBRK3n0tfCa6Fa4jJLBtxp4Jz+Kv2EGGzJBRIp/T15cLWKZ5AZUm5xQXUOhI1Mkbrlfm/SrrvfYcmQLGzIMYxSFhoa/yh3NHBkZYmb+26cYcdZkkUDbqgitmOeb7XNTGg37isx47JMGOBTZCX0qv8IZS24E5AOxvHGhDDI6KP/PSMWSUrumOTRhjHbKDibk1dLr0fcySr5/z/jrKg45vZUhpvhrFM6RCTLkMn726v54KvZG8dzuULv9mfBgwzVeNwFdNLX/O8NEI+QVoAHV9QOSKnfkyboSyud6ZuatjtCKCaY3hrRH2ntoj0hGQ8Epf8DiL2K97l8Frl5OyrwOt8dAkZNB+6MiBiNI4R4K7VAIqDkIpFN2ML361mTPvCh9OIDqo0BSlvFBQuGtDEfYkGkmY+af06fh9z5TYI1zJWJJpObDdPkiXHzVLR7JfpJCpz8G5Ia3wBPDtArkOievgMDkUbmjDDPl2Gx4ovgorqlo3tLjoBLUwcg1EFLzW5WQg1SdKcdXpaY70ZTCGArjg7wqTwx/AmnK+2QrGpBSp+zmSHDW49WfMOES4dH3ngTr4IzLXf8wYMxEgOIvGzLNwe6lsDzVGx2/X4i4BlcFUmJbYPjfgCk7hYt1TI8crL8iFitHFmPxBfVYdOXlfn/MlKkf7kqVDNNqUGiDkhtTPSt9bIrboNX1fES1s3qnNWbmhindG7x9JWU68y0oeVTF66HWDsFfpaZHGEMBGTNfXvEl/jX6X/i/3v+H8zuc36oGpNRWglAaMy3SKdtkESXWhGFjpttY1Wtcr9ctXGFDprm0KpTZ4zXlwBdzgD2fO7dZ2AuWRePRdf0UDPv6Opz92fmY1WGcz13PHDKTK5YYpqnGzJRd2HTOG5gY/yfclZONoxbP2yA9p+UHTUkij0Yr1NScM3NDkLGx7bUm7MDkDEkMusVpxFCIQirTfew0YJdnewa1dgi68zo0PEdkFFARw1/7/RVX97i61Q1IrfJ38tQEo7eUv/Jr0om5tWEKCuGp2Kwd9TQ1GiWua1x0uybdGK3tfXjdwg1O9m1GrQrVhKxP73TFshXbVBzByNXz8MTIaZh75L8tLsLEMNHC8t3FuGWVBcld/idu52qad2S8PJeViPtKy3CPmgJuS8zM9UJejkrqsxMIrnPqexWw4Wnv+1J1KbBkEnD4DmD0Qx7VmaRE7lCpwGxqGEMK7WgpGwdL8M4fzVUV5Qt52I6MmVV1/d3KvqeYDmNKzIfCmPH0fJm8jRJ6pARe+us4xFsgkbxtZLhSxVIEwB6ZZtSq8MYB1BzzYegAI7e8iRV/XIZXC17FvHPmiccVl6zwMGIoyW1r4VYs+3WZeGyupDeGiTSkGS91jjbHlmsWJZHRQoJ56Xa7yKOhvBk5uUk5zTozb5b8GJqdi4RnGfT8steBXaRL4iOOseEp4IePPaozCenjowpM33kd+sMYrR7aURwLhfPHnjpWPDb3eyrDdqT8vsneA3WIwZUxXwgDxit8l5rvWw9G8tBQagOlOBA0Dn3xSMQI47FHJqQS7pxxZMvBzRigUQ7XWrLZDBMJSDPemFSdibwWC8ZWVYt8GVIDpueUHNzv8mdgOfk8hAR6kzUpf2L0w409mCSNF78TMBef3w2cPl7M9iV1YjIK6fOkAZfyOl6IW+iSjHPoDmOQcakUBtTqGE6hnki516mdt1rYTqtvX+MGj/gXtaOUBkptUIkERIIwHhsywSRY2d8aBpEkm610tyq1FRiG8T3j1dthWqposigVcKtCoFJJWVpOg5KqV4W8IfmNwnTKSZLeCRjlzsg0R7zViQfDXtsPlhXTPQ0joSMzV3WgpL5CkjEkIUT1xvdATArlhHiej/J5uKJ13v8Y18MjbOe7GowwASv+5jYwA055CHNhPDZkWvSG4gndIj1mebV14oZpS87xEthqTdlshokUfjvqVM+2VXeCvSENphj18JK7m7WKfH/IlaxKpeWiIaZGK0pfSZ1GzkXZSdtLnfgi4PQLvb0+ivem+9kLm1dh4dptsAujspM704EG8ds/WYTEkxZ7vX1JTUnITdrUPCu+2jRITSGVd3I678lvbcf/ndsJL321T3xz/lR+3dVgm19w5ryofcd6Uh7CXBiPDZkWvaE4gMQMkey7OinBu/Os1Yr/O2rFk+/U4h8Tjng0hGtN2WyGiQRoAFm4+mfXM7PoIC2atHo2s3aXhkwrLfOaUNCUoSYxF99Zu2Gg3aG7r1CLlZYrkzp9eEPckKEhqpVK/b+PDqOHytm32Hug2HYqcuwJGAizx+coD48ntHcuI6OSvg9rZS84qO9c7qduZ0EoT9p8eZS8GnrKcrR8+Eaw9LsjePaqM/HQ5z8ip1JnNdiKvwEbn1FVUNbtcQtjYTw2ZFr6hkI/5M9uxtScTK+LmeTSH8qNQc2hb3Hr4gZ3J9zWls1mmHCGBo9Ne0sx/YOdHr85GjRrD10tBk1TbGPH+TRTCmYW/YYLqpWJl04j567yK7Hila0+B6xWu/dQeMCPN8QLWj92gbM6yRc6knX9Dexa4XHyjJFRSd+Hw5YoErFDfdLmy7NCy+X3b19ignJoX7Q+PTledDffs7EWWPWMvgOq0Mh30etxCyUvo0HYkGnhG4oIEe04FY76cq+6T6qUoMkg3VirK3uIGwLFoGnW15qy2QwTrqgNrFAYM9bKHqKKyRRTiUv6nI5H/nARLJQcqZiMUH+02Q3XiLJYfwNWq6GWA6OHXhc7S6ypOkkVk1/NEX8D+7N/7oMFe9TD43QrlO59dcUFQZm0GQ35GEGPZ0V+//YlJqgGbUev6zlkDLBZb7qCQz3fxUgOVZjChkwL31BEiKihQrMZndCwiC0XTSSPlHcRP0SKQYeKtgLDhAtaA6s3ZneLkKHt+zrDFa7JiO23rzH7rTX4uTpZlBhTdY6eASssIZ2Y9mc5q5MosVfuifETntIzsM9c+Rlqs7TDF9K9z2SpavKkzWjIxyh6PSvS/VtCrSpJDfd2PtMVdOa7mJuYQxUGsI5MC6M39DM74RlRdidZ8KGkrcAwoY6vgdUXHgON2YItjp5YdGKA0PKQGzFqA1ZE0PNi4J6fnaqwl7zifHS1VWnqwF5WpyMHh7a1tRE5M1pfnj9FZcmAVR6P5Bmi9U3FiGdFjiQmqGXy0nJaT9v5a61hKN+lh8Y+/GnQhAnskWlmlO7NjETqTuqfLrZyTIxdiP+VdQXwZ7FMS1uBPDFkxIRKFj/DtDb+Bla1ASRPOYA0YcAKawIIT+k5f70l77CmisRfqlpyKtI4dE/aAg35GMWwZ8WFJCZIBpWGb0Ss9zo2KV2BqpMosTeQfJceAeZQhQFsyDQjau7NvLQ4pJ2chYqGUvUQkavss39dnbiyu377T+C8K90XW2vIZjNMuE0c/mNg1u1rAAl0wIo29Jw/lbynx2XjeP1RdRkJBxk7aciKPR2zxvdCTMpZhidtgYZ8jKLWpkGPYUwoxQQl8vyFvugeTyXWVJ0UaL6LOcAcqhCHDZkWjs8XldfDsm+MqkaCSa3sU6W+X5LNZhhGf2KvOnZkZR/CnwakIjPrd9jsOR6TgqYMWGEFiaY1YaYufU7F5dUY4OoNRP2XpLwi5+eUhPuHzMA9X97t5WmRcmRu7X03bhkw0mVQtvOYtGUkZMFWfQqOljVgo7VUNXm3pTxoAXtWXHiLCepMRo6CfJdAYEOmGfDn3rRV9kLCsb8gLfcDZ+KvC/LEkBEzsromYur7GSa0EnsbScv8EaknLcPx+hK8tQ/iT9nuo6kDVlhAvXZU5SJUNEk0oPN/rt/vyN0wy0PAjfovPdhwraj0os9p9CntsMDkHR6nnBc1T4s0aaPv9653yUjd6jN5tyU9aAF7VjTFBFtAMyhCMTnCXPO5oqICaWlpKC8vR2pqKkKBjXtLMfHlTX63WztwM47+/IKXsq8XlHAXge5AhgnWxGHYvDUanhi7u7SacjQovGEigbaUXepeUZd5olSObe4qmFY1YsTsXjkMuAwzvYmgrv04BesaoSaS5GnZMeQpnFnQqFNDMhR6w+NaRqr0PvLyd+la8OdB+/LeEdi2vywopdnNWebdnF60SBq/2SPTDOhxW1JF0infPymEubUJ//p+hmlutPIiYlJ2CV0SubgaVcMkVl6MhNzlKG/w3peWcmzAoYBQJlg9eGT7UX4a9PHQ0m47HsHGU/+AgZ2zXZ+ZGdaqU9FQmQ+rg7wjZtVB2l5ZiKWfHoYJp8Kh2EYteVePB21Cn3Y4b/7aoBmlAXtWmkqE5rsEAhsyzYA/t6W8EZgW0g9wa/f7YNt3PPxvmgzTghMHMmJIKVYJGTV1GW+gTsWI8acc22oDVnMRrB48fvZD2TBJNYV48rU3sD+lnzAkSIZf05CQhbrIdHmOQlTxGaK7tiRG6Ct511fIh96b+hgZUeMNWY8M44YNmWbAX4Kgr0Zg8kaSa+qGYclXmcBXmzx+6EbcsgwTfRMHV68eVwJpoER8u49g9eDRuR9KAN5UXosXv9rntU4yJD4ccRRnbrzTy0uUh2N4PnYhbm2Y4mXMqBmzah60s05Ox8BHVge1NDtiQ45hBhsyzYA/9yb9oNVYnZSoaCS5B8kN84SmQmF5L7G/28ZVY0Xhi14lifIERYaJ5okD5cT46tWjF5okRPSkIVg9eHTuh6qYtBDfG+zI3zjbK8/GHaJyADNj38Squv5e4oRqXnClB+3J1T/jeHVD0EqzA+m1xDQPrOzbTEjuTXJnyqHnf+1rUjVipuZkochiUW2mRsmJ9Ldo74NeXbCpbQE1YqOGbAwTcVC+xL51wM4lzkd6rjJxIOiXRYm9TUFSji2rLUPBBwW4fsX1mLZumnik5xHzO5N68PjSmdXRKNLffijh97AjU5Ri+4LKtnNRqn00JiDfVCo82j6VcF3hHiq6+GTHIfFYb7Xjta9/Q7ByHP1VphK0nrZjmh/2yDQjqgmCtethed+zmyndlskT41DxhTc2U1sqnqt0tg+51vYM06ylwUmZwBlXAN3Guis15HkRxQ06FWRVkKqW/tDpD7jny3u8tE6kSYOyqiksCZYmiY/9SOM4NdtUa/EgJxf62jxI22mVvy/7/gju/2QXjlXVu5dlJMfieI2PxCiDpdl6hPeKyquxZ+My9EytCduqonChWT0y//znPzF06FAkJSWhbVt1t+KBAwcwfvx4JCcnIysrC3fccQfq6xsvwHBHcm9e1Lc9hnRqC8sK6pfkeXOknBgRTvLRSNIcWyH+tGL+8gRFhokIpNJgZSJpdSmw6TngjQuBhb2c27kmDuunnY9FV12J1Fh9rUCUUJj2sfMew7J9y9TVZ13LaNJAYaewJ1g9eDT2U4hMzbwWJZmmRk0tPduRd1sZvpmzbDdue2u7hxFDHKvSZ8S0TYrVJW7oz2tDVanr4+9Az1VXAR/cIK7Vuvmn48d3/o6fV78G269feXkWmRD1yJBBctlll2HIkCF45ZVXvNbbbDaMGzcO2dnZWL9+PUpLSzFp0iSQtM3TTz+NiEMju58Se4NFxCcoMtGBtR74bIr/br8k1U7GjmvQpYnD2V1yMDv278JzomaMqDGxvBKjqmvQb/xD2J6Q7hW+1VPVFLYEqwePjo7hvih16NMRGTu4N0b1GOxVHbTs+8OqicRG+MvQTroSfX15bciIocRkJXHVRTh9j8sbvx6oScxD4vj5USlgF1YemdmzZ+Ouu+5C7969VdevXLkSu3fvxuLFi3HmmWdi5MiRePzxx/Hyyy8LoZyIQyO7n8TwgoWv1vYMExaQh2XB6U7Pi19chgrpnchmuFKD1fT4dF1vOaq6GgNIkHLF31BSVRR9kwZJk6T3pc7HQEMgZgssp56LoRffjM32Hl7aL74ogr42D/179RRebrnBQbkoFE5qCuSNuf38Lrq21epiLZfWUNpDSm96fHUhHGSEuzyKTJgm+27cuBG9evVCfj4lijkpKChAXV0dtm3bpvoaWkdGjvwvbNDI7idF3zQyZjRElmmxvSEVdmuS1ibift42vq1ma3uGCatwUvVRAy+S6Z24VGO3Fm5Fva0e13b+G+zWZM3fDfU3y7NaxW9Q2k92hT5DhicNxosdaPC/+dxO4lEJeW+opYHP/FiN5GPKWdEbPtJi7p966y67ViaYK6U19OzGKRbogENhhDNhluxbWFiI3FzPwT09PR1xcXFinRpz5swRnp6wRMruV3QuXZuUiHKzuk0p3YDrii5EfN7HmrumzRps9uAfM8OEhNKsDk4UiYoiZR8fIBFqmfKqTVppYmFJEbkylNir2qEeJrGeJw2+8aWGfN+Y08XywopaPPTZD8IIoRAUid5RWIaMGbkx4PzqTJrJx0aaQKYnxaJMVoYdqO6LmvCelrSGFuKur0d0kAmuR2bWrFkwmUw+/7755hvd+6PtlVCOjNpyYsaMGaIvg/R38OBBhA1Sdr/A5FGx5Fykfs4OW5L4M8dUayb70vIqawUn+zIRrDTrm9W1h0VejDK/xWSpcf5uFL8datK6oPioV5NWS0o7ocskXqt4kfScGhxydaDBYgdZOEhanpea4OFJoaRgSg4uVISZ6pPa+Uw+NtIE8qnLz8Dn44Elww6Jx/X3nhew3ouUYP72TYPx5JV9cfO4ANvJVNLklmkxj8ztt9+OK6+80uc2p5xyiq595eXlYfPmzR7LysrK0NDQ4OWpkYiPjxd/YYsru9+2fBq215diU0KCTADPG7oBm2KqYUnaG31xeya6CLjLuwm21HzM/W2pugfFS6/Auc29Xp3mG3ubjTRbRI6N0rtDnhi1Ls1MYKh5UsiYIdE7CtOQh4OE9CZedAUu6tFRs2HiwJOHoG2i/xJrSsTt//FdSKyVXWubjXX69im8Z89z7k/hdfcLhZdiEjjxt6UMGSqRpr9gQNVMVKJ95MgRtGvXzp0ATIbKWWedhbBDZzfS1clJmNuhPYqqgx/Z47g9E/FKsx44rZTtQ/8PRT+9ovMlJhFWmp+Zjguqa1xhJW/dFDJWSJcpYpV9QwAtTwqFmTbZnTkoxJ2pyT61hSyp+Xi42524fUcHv9VEplrflW9NQqap41T30mnMUGJ7sI4hCmnWHBnSiDl27Jh4pFLrHTt2iOVdunRBmzZtMHr0aPTo0QPXXHMN5s+fL7a95557cNNNNzWppXfICHelelv6FMM3UhYqYas+FfaG7ULpVyu8RGqkHLdnwhaNHDIPTGbAYVf8xuaiJCEG+En/WzlMJhTGxAgNJ6pWkvajHETIaImIEusw7UtHtzpKGHZru0jJ4MqtK45gXMV0rEm8Gx/WeBc8uKuJyMPdlE7feiavLq+7STEekCPQb++vQI6BaV5D5oEHHsAbb7zhfk4l1sTatWsxfPhwWCwWfP7557jttttw9tlnIzExEVdddRUee+yx8PpqfPy45FY2VVOQq9qIEUMXv8OahuzYnvhT13y8+etDqj8Isv05bs9EvNLsJa8ByZleXs8D370Q0FuWDLkV6DiSVVdbyVvtry+dh3Kvz2Rwp//jnwmL8UlNX9gU6Z+DzLs1G/VKrzecdOtv8urS5vnuxz3YvO0bXGL9HJmoDO4xMAKTgzJrwxgqv05LSxOJv63ixaEfF6mLaiYpuuLuU3Zia/F20a9FL9I3U3voalx8WgHmXdoH/z2wGg9vnIOy+hIPTwzH7ZmIQXWAaK/qMSFogkA9kHyJ2GnxasGr7HEJAW+1ri7S1GeL1Jz9sOXcN3Dn5hT3viik9Gjcv5CGE/6P9ZJXnFo6gU5eJfNLESIinZu9/30VXb+eGrxjiAAqgjR+c6+lZq+0aLSySxzGmtmRJ4Y6X1sre2HJ9kP4em8pZo7vhbVXrOK4PRO5GFSapRwWo0YMl1CHlrfaV6m20WTwgdlWUUlE+7L89CkGbHlSf+KtnjwtP54htTAVnUfXLl2Br4N0DIwHbMi0VKXFiSJkZ5+sa9O6khGwVXeBrbqTR4W8Z3t4jtszEYykNOsDmuXSYLXqgIHkGC6hbjkMDvge1T9NGeDb5Dr31akt8Mk8nUZMY8VaMCevHtew3xwwA8fAhI6yb0Rg4MdFibhUvqnUpvBU8E1D/dFRsFV3dn09dlF6HZO6A2ZRgm3n9vBM1EOhiLPnrsHElzfhjXX6uiZL0G8wIrpXhzpGBnw9SIaAxv3TaQjIlH+N6hJJFWtkgFEYa+cS56NSddfA5NWfjpjHscuPgTEEe2SaigErmyogSGiLqpachXkOFQXf8W77MiZlF+JzP4U5tty9HRk6JUXjsWVfX9+zF4aJYCPmlsWNXd7Jc0m/C18Vfckxybh/8P3ITXZOKLiEugUIdMBvSjK43BDQu9/EdGD8U86Qpp7qUwOTV80u4arvoZ4DxviHPTJNxaCVLTWzy0nK8dgyPS4biWV/gb2yBwabd2NI6hIktl8sbs4ee4wpR0L7xVh7cHWTD51hQh7F7NhmtWL6hzsVG5ldEwDNdmWoslYhISZBJPayEdNCNGXA10IyBFIVSrxkCCg1WPTu97I3Go0YMpKUXhwpn0dq7mjUM6R2DlN2AZM+cyb20uOUnWzENAGuWmrFSgul0BZ+/Aw1S+9FYl0RCjrko8hiURUeoJt1RnwO1l6xkm/KTOSi8puqS8rDHcevFOqvntiRfNrDMFnU23hIyb3LL1nOv5kWr+j0462mQVwlnCLlQKkm/+oRHzXy/oTO6lPxPu4kZqh7hljYThdctRTmlRZeQlv0w3h/EpLhwDcJ8X7bFpTVFwtDSEusS81Q4pkoE+7VLnHVhUKdlfrxyI0ZS9I+0YtMCwrjFlYX+vzNMEHGaChIht9ybB3J4Iben7x+RhJ49YSIdCq9M02Hc2SCiZ4fl5/sfvp5lZAnpgl9ldQ6ANNslPJzOMGRCedqF2k4mhn7pujHQ1L2YnmMPmkD7kXWwgSQE0JGDFVnKr99z6rNdsF9/0DyeXxNXnUqvTPBgQ2ZUECRXZ9tU2TJ++mrJPe+HKg4gGe/e9Zr2+LqYpFkzNUaTMjjp9qEogv5KBVNBaV+PA5riq5dcy+y0PZWUziJPDE+CrbFetKc8dCYaer7B5rPozZ51amdwwQPNmRCAcVsoF9tHXKtVhRbLKInjC8xLzXvi5ZrnV43b8s80QiPw0xMyKJzdkydkfVWLrEAXnh4qyknRh5OUkKmAa2n7QxVbfp7/2BpvAQglsc0Ha5aCgUUVj5d3tNLy8S/qUuvHEmDhloSrD24VnhZ9KqaSnkCz3z7DLYWbhWeHIYJOXTOjovRVrVySYn8N8MGfGhDib3B3E43wdJ4CbZ2DqMLNmRCAZVyvpHVNVhQfBQ5ijCTJOZFXhWjDSgl/rXrX6LnE/WnIY8Ow7QEFDbYuLcUn+w4JB7puSo6yltrEvNwIPkMj6VZprMwqfMD4jcihwXwwgeqTgrmdoYwUtrdUto5jC44tBQKaGTXkzEzoroW2xPiUXL27cg+bYy7+og8KoE0yZNDr+e8GaYl0NUU0EC1SeL4+VjXfbRqee5U+5+4Yi9Moe+QrgtK7NUI8CAvzfldh0L1aYto5zB+YR2ZUMKAFs2yX5dh2jqKxTYN1tdgmhutKhTJ36JZhWJQm4mJrOsF6gXTxqqWwkw7J9qoCFL3azZkQg0t7QHF8q3xsbh+1U1Be9tXC15lfQ0m6FD4aNi8NZoJnNIMm7oVq1ahsBZHVGLIgxdqsFieblgQL1LRKudTzEz7peYjN7sNim01qpVNRmF9DaY50FuF8vrX+3Dd2Z28jZlAtZmYsIaMFSqx1lT2DWW4n1KLwzkyoY6GJoGl4jCmWxMxNSdLVDZ5GDNU6WTQuGF9DSYYKGXlC8trdL3uoc9/xL/W7wuPGTfTIpDREraNcZuaa8MYgkNLoYw73qpdzrc6KRFzM9M9WxoYMGQ4R4ZpznBARnIcjlXV67wWwyAHgmGYoMGhpWjAryaBVNlUIyqbNiUk4KX0NMPeGNbXYJorobdMlxFjF72SRJsBawpmfRpnTLmVYZiohkNLoYxOrQFyVg6ordPdo0kiLylPGDHcf4lpCv5k5X0Rk7IL8bmfwhxb7l5W2ZCGF7aewORBf+QvhmEYv7AhE8oY1BrQ26Pppt43YUj+EO6IzbRIQq9ERnIsjlU1eBgxCe0Xe21HbQZe2PMAuuWlsJHNMIxf2JAJZfz2/4ChHk2SF2Zy38ks1c4ELan3f0X6Ok//48KeOHaiTiT2UjiJPDGE8lKVnnNfMIZh9MCGTCjjoXDqHwos3Xe0DPfkZjW2ilXk/3I+DNMcSb16yEtNwIQ++Xh53a8ose72CCepQX3BqKv7gLwBTTxihmEiGe61FC6aBInpujYfXePs0ZRit3ssJyMmLS6tmQ6SibakXiNGjMklZibpgEwc2NGZ2KsD1jdiGMYfbMiEizFz6euGXnKCKj4UnbMr6itEbyVuFMkEO6lXC8kpSPowZMRQx3V7wi8wx+lLZGd9I4Zh/MGhpXCB1E115MtQui/pyjhUkg+kTtkPbnwQtdZa5Cbnaib80oBDbn2aEdNgorUdEz3oTeqVk5YUi78M7STKqcmApo7t1Kw0Ptu35BEtz4jPEdcdwzCML9iQCcN8GYeQsVM3ZkhPxkMcT4WyujLMWD9D/Ds3KRfTB073qA6RDzgSatsx0QUl9urhD73ysHFvKY7XNOB4dQOeWP0zFu/8FLUZr6lurzRmxHMA9w+ZzsYzwzB+4dBSGObL1CbkaG5iVEumuLrYI9xEj/RcbsSobcdEH9RyQA//2VUojJhG7KhO+VAZ6RSoemOsabi28wMYfcqoJhwtwzDRAhsy4UaPCdhxyXpcWX8/nmq4OGAtGWW4iUpd6631whMjLdPajsJOTPRBybqUtKult0vL1cR4SbWXKpS0BKel5XUlI5BwdDLmD3oH955zWfAOnGGYiIYNmTBkYOds7E/phydtl+KwIwN2h7eWDDWS1AsZKVTq+u7P73p5YtS2o9wZJvqgZF1K2iWUNgk9pytOfi261+msUJo8bBg23XUzxvY+KRiHyzBMlMCGTBgPKHaY8WCDU2NGGkAosDS9tEz824gxQ+yvOKBrOy6JjV6omSM1dcxL8wwz0fPrzz5F9TUOa4qufQ89pRP3V2IYxjCc7BvmA8rsTxNwayUwM3YR8nHM3UhywQk75mako6ihQvc+t2zeB7T1vx2XxEY2/irW6NqjKiRJ2ZdyZyjs9MyaX9T3V90J9oY00XpALbwkdWDnCiWGYQKBDZkwpnFA6YutFTegS/VOnJ5SDXNKHkaePBQjqIqpeDuKqorw6NZHcbzuuGr+C5FttWNJ2fsY2yZfs8UBDziRj56KNXl7AsmIWbW7EAtX/6yxVzPqisaLvkrKCiW6pghWnGYYJlBMDofB+EOIUVFRgbS0NJSXlyM1NbW1DydkkaqRlIaMFH56vOgoRtXUYHVSIqbmZIllcmNGGnAWDF+gWoKtNrhRCIyJgGtE9t1bK3t6tSeg1gO1VpsotTba6Zo7sDNM9FIRpPGbDZlIgKqI9m8AThQ5O2ZTs0kV8br5697HOz/NR31sjXtZntWKaaVlIhwlsTIpEQ9nZaBMVsqdHpeDB4bOUDVi1HrvUHUL5fGQ14gJj3BSwQcFmsneZMykxWbh9+/vgqNJqXV2UcWUnFSNKcP74+q+wxHn0j1iEUaGiS4qgmTIcGgp3I2U3UuB5dOAisONy0gBmMTzSHfGRb3ViiWbSzDFXga7pRqZdjtybTZR5SQ3ecgj82hmuocRY7bGY3THGzWNGOq9o3TrFZbXiuWUx8PGTOgjQpB+KtaON5QgJv1rOGwpIoGXcl+M1wuYYavujIpq4MEldXh51ZfC4I1J+YFFGBmGCQj2yIQy/owUWi86YyvNCKfu78/nPYs96cPxe90WvPPr0zheX+Legkq0pys8MVJYyau9gauT9hPDn/AwZiicNGzeGk3ZepOrmmX9tPM5zBTiBvIyezmmudSede+iIU3kvlgrewV8GHSNWFJ2IfGkxSrrfIczGYYJbzi0FOQPIuTwYaQIqInkyhmeRo4M6n1d6MjEeXE3Ib79W85XmbxzY6hTNhkzJHFX0CEfReSJ0Uz0zcHys/4BS1WJGPw2Wrth4itb/Z7K2zcNxpDOmUbOnmlhA3lrRntcn2ZMFVrKrqs9dHUTjBk7krvMgzmm3FucRpZgvvyS5dyugGEijAoOLUX4bJkGGtUKI5d7ZNndQPVRzV2Qwz/XVIo2uR9DpGAqBglK5CVjZl5mOkZU1/jt0eQUwyvCc0uvweDaWhGS6puQiwLzRKywDwxKjx6Ck4Zbx0Dud+wwcpPboTgmRnd3a7J3yZihBF5rJQnlGc+dkVR//YkwvvntWqRbTudEcoZhvOAcmVCEXP4anhYnDp9GjAQZJ9bYak1JeTJmCmNixHZ6ezS9lJ6Gl5AmQlPTSo/j+diFuK3hDhxHKnJwHMVoiy327kKsz2iPHk4abuYwUuURYPl0VQPZAgemlx7H1JxMmExmzTJ9NWPGFFuOmKR9SEF3xMeYUVhRp/vQ9Kr+PrxiM6yu/XIiOcMwctiQCUUobyEI6DVOaLssq7H+SaQ1c3dOJh4rduDZqmdgMVEwywm1TZjdcC1W2geKHBkqxfYHJw23YJ6VBiOrq7Gg2IG5HU5DUf1xQ29DBsmcCb3dQnlf/3IUz6xVF8gLRPVXvh0nkjMMI4dbFIQiVJ2khyTSe1H3t1DLApM1WdduqNGk0R5NksbM/Mx0QGbEEHk4Jjw1Y8yb8eSgSlh++ADYt87pGdAIJ1H5tlYgjaD1tB0TQBhJhxEjQflS/+lxO14teBXzzpmH+wbcp+t1U0acJarTSDuI8qHuGtUVbZNi/b5OUv3VcgDR5UjrnRVSrmWuR74mGIYh2JAJRajEmqqTfPUZTm0PjHu88bkMabz/qPIqMQho2iaU39CQgJNr4kTXYqM9muShKTm0L7Jzno17GgO/mgR8cAPwxoXAwl7OwVUBzeC1Kp9chynW03ZMMPKsfHPrR4exYVcaCk75A67qfpVItpUqiNTITcrDLYNGeSwjpV9/AnmEyaX6S7tXvod0GYr1ilsVXxMMw0iwIROKkE4MlVhr9hmm/gRzgZ4XA5cvAlI9RecKkYlbG6ZgpX2QaxBoHBQa9yJGDkzKuRg5pkpxIYgeTcVHkWOzNTmERUdpFrVTMiqOOD0ECmNGbzKwkaThqMdvnpU3ZAAfdmRiTW0XPLH6fzjr4VVYtbtYtCcQOTNKm8j1fPrAaR4VRZKHTQ8UenzmomtFaX9OUo7n7q1pfiui+JpgGIZzZEIV0okhI0VVR2Zuo9gdPXYf59YE2VISg4krLe5kWxoEaDCgyhJKypSgWTb1t8n+YZ/H25IxI1UxbUpIEMm9ekJT+nBVXFHCKR2za/DTmwysdzvGeJ6V5MWb3XCN+9ohjwqJGv7fuZ1Q87vzGpJXGNmtko5MT0MeNol/jDsd150tdbxuhxEdRribVRaXxWHW+zV+51p8TTAMw4ZMKKMwUjTbD9DzTueIf1Ih9LM5ni0DyJjJMvfDNcNt6JRrd3c0ptn2nPXf4p04z93R3gfU1om8mU9SkrWbSDocbnVg/TiAikPinGwnDxUDVymKkZ19EEdL2qvK30vCenqShhmDeVYyLx4ZMcpSerJvXl63D3ZHL1FiTeXSlNgrKftSaIiuNUrylXpr6fWSZKXEewglkldnQN4At1fnxZVrRGKvWnCMrwmGYSTYkAl1ZEaK8a7Y2k0cJfd/kb27qDKiBF1lj0cyaKjEmqqTaJV8QJHyaKhPkzEZNSerD36Bud/MbpTFzwKS0ryVYqVDIhl7bkJpQIen4mSMScpDXHWRS+fZEwdMKHWk4KGGq1GEDK+SeTmNOdbO9gJa+UuS6GEwPGz0XdN3Th4hr2vP9cjXBMMwzjsTE5FI1SMX9W0vHpVGgOT+p8GLSqUJZVEQPRd5M13+jJwkzxl+bkIGFnSZiJHVNPs21uWaWiHcte89r94+FLZIbL9YdEmWIE8M92vSB5WwU8uIiS9vwp3v7sQdx690Scqp51n9veF6fGIfhk32HppGjF7kXhgymknrxUequljvz8NGBjl993QNyOFrgmEYOdxrKUr5ZMch3PnODvfzAvMWzIxdhHxTY2UQJX7+PugBDBx7nXZnYkrc/fROoEZfRZENJpzX8SSUW7SNnwRzEqb3fAf5aalenqRIoDm6PGvp8Iwxb8EDiu+VKt5sBXMw4MNEHKvyX1mkh7dvGIAhMT+5Q6DLT3TCrf/+TqxT86YYMU5Z7ZlhIpMKblHANAWlW59yI1bV9cdA8x4Phd5/dxvqlb/ghcuIoZRfSSVY0qbxHJ5NeLltqk8jhqi1V2P+nol4+OyHYTFHVrPA1ftXB73Lsy8dnuWu77Ug5Vc8Mz4f5pQ8kWdF3+cff/0Br3z9m9/9K0M7ynVXtNmBwZ/e45GUPiY1Hx+OmI7btp/kkfhL3hQKCRnpiC55FxmGYdRgj0yUInWu9pdM6bNzNWmVkDZMxWERLpqbme7Rr0nZYduW2h7n5bRBua2x47YvqEQ8kjofkxEz9YupXvL/Te3yvHFvqQgnGW3eqfd148/Iw2ffF6p6V8iT93zckyp5OM5zsl32BrYkDNPM1WIYJnqpCJJHhnNkohQpmdKHUo3/ZEqXVgkZMVNzspyds2VQtRMtX91/IjDpM2y/8lXdRgxBA/68LfNEKCYQ6HVbC7di2a/LxGOg+wkG9N7kiVHrYSQtC/RcA9Xh8ZfLQqQnxWLhlf1Uc1XyU2PxRNo7qsnEksljWTEDQzq11czVYhiGaSpctRTFSMmU8lJtQ+7/n5aJcBJ5YsSwpSjRdnfYrtiJEScPRclvKwwfI3U+fmvPW8hMyDSUT9IcIZym5GtQTowyuVmtyzNtpxnC0yDQKiFflUEELZvzp95iO9VKONMPsCxyemr8ldobrbxjGIbRCxsyUY6eUm1VyHPw/XsiJ0YeTlJtY9BQIQZoMkQC4dGtjxoyRrRCOMXVxWJ5oCGcpnTnpsRePejdTs2zokdzRZloPKqH09ui57y8clV2FrdoE1SGYRg12JBhAkumpFl29VGUJCfp2pwGzoJTCoQh4ssz4Y/i6iJM/eIuLDjvcYw8ZbThEA7lo1AIh1RkdVUKkcG2fwO++3EPXl9/XOjuyCOyejsx6zXi9G6nNEj+cWE3TP73d5qJuWSUrD34X00v1fppFxg3ZvWK7hkU52MYhjECGzJMYLhm2XrbE9BgS4YDDZpq3hIYaXJA4ao1UzFi0MOwUL+p5grhUGm5q0VEH0AoIJN4IOnuSAq4rqYLXuq2SigkRkYDeYXUzp0MLFpP2wUaNrtt3M3499o0r2aNaUmx2Fm2Hm9ue0jTS3Vb39vQMaUj8vOk8J1Jf3NT6qGl5Qui9bQdwzBMM8HJvkxguGbZVGJN1UlaHbNFWCMpzz1AU0iHQjs08AaKCFdZTNj+6c1eDSibGsKhHBiq5tmy7HU43rsWDkXjRVJAfj52IUabN8OStBcxqTtgTtqLI+XVPrtzS0YcoezyLD2n3lf+vERkxNz1xV0oqvI01uj5ol8fxAnLt16vKa+uw+s/PanppaL/PbvjWUxbNw3Xr7geBR8UiPcJWnPTJmrkMAzD+IINGSYwXLNxC0yixJpQGjPO5yavAZqMmWV/XI6Eo5NRc+hy1Jf1g92aaPgQRNdtakApq/RpSghHUsb988sbcNLm2XA4vDVxyVFBVVr/6/wBkk5+GYnt3xGPyV3mYe1B34M/nfd1Pa+DSZEUTc9pub+8HQonzfr6n85O5mp2gwNom7sEg8y7PDqPm5P2eTR79IfkpdFlzEjNTRUd2IUnhpZLzU0ZhmGaCQ4tMYEhzcbfu1a0KVhQfNRbRya+LaYNnaU6QG/bX46Skg4AOsBa0Q91hXZ3Q0KTpRIJeZ/7PYRsmxWo8qyKkUI4vsJLcg+RmjLuYPMeTyVcGWTE3JOT5V3hE1OOt/c/jIH7MzUNEjIMXv/hdS/PiN1hF8vPyD7DpzGztXAbyhuOKovDZAcB1MXW4p7Ux9G+JtkdAqPP1AjycnBduUR6m5syDMM0A+yRYQJHNhsn0bsVBw/j1SNFmFdpx6vdbsDyK77UHJi9tU+cDQmtFX3RUHY27A1pmnKy5OnJs1rdXbd/3vuLCAkRNOgW5N0svBbKaJe07Iy00T6VcUnZWA1fpebS04c2PYR6a72Xls1nez/Dgxsf9JkbJOnIaOnfbD7gX4VX8lRJITASrKNO1YEg5RIZam7a+1LnIxsxDMO0EOyRYZqGbDZuOVGEAb5m464KIJq1d6lKFOEP9WaFZtEFmxpIktFCOTG+um7PXFOM9M1P4eYzk9Crezd8vC4NtY6rEZ/7KUyykIq0m5VHFuG7D1a4y7ilBpoS1J5BDX+l5sSx2mMYuWQkHhjygHiuTMr1l4T88s6XseTnJaqVRXZrG+iBErApBEa23czYN7Gq+glhGJLXSNObo0FRlc4Sa4ZhmFaCWxQwLYOsAkiiCJmYWX+N6AfkdWHSgJzzI1Lbvo4iWW8m8sSQEUMeIBqoj6MNahGLfJMzT4dorCzqj7jMNYjLduZ6KAdxqQVCVdnpHg00ycBaH3+H8GrIi3eWJSdhWk4WWhopGXhk+8uw8vf3YTJpJFY7HMi12bD84GGPHldX1t+Pb5LtTsPQpN03SY27ez2B686KjBYRDMOEFtyigAkvI+a9az2MGCIHx/Bc7ELRoVmOZDs8OPrPWDHoYbx6pBjzikvxryNFeKikFPUmEzbHx4t01rY4gTw0GjGelUVbEZu+1blPDU8EhYJ+rVknKpDgSpAlLxEZQuLfslFfb6l5sJEqi1Ydek+jHYArbqbwVEEWKrNV9sJf0ycgx2pVfZ3a7siLk2buGpRzYBiGaS44tMQ0LxROIk+MqnaKQ1gts+LexMra/u4wk2eLhIsxwGTG6jXT8fdEh0doJ9tqw/SjxzC6xrN/kxRW+WPKW9gYq10NRcYBhYJe/fmfSDrZOXBTSMta2Qur7P3xhPVSXB+zHOk40VhqbnOg2KJpTgQMGQ66wj4a29AnN7/4qLtBpxxrcg6en9AHY1bdgxsqDrs7lB+IicGz6Wle4TvJtqHPIi81OeBzYhiGaQnYkGGaF1djSS2EzgxK8el4M35J7quqKrs6OQlTU2K8EmWPWsy4JzdLVEwpB3B6uSOmCoD+sm7KIUlovxjdDw/CU3X/9ahcqo9NQ9zZkzH9lDMx9ct7NATgAsdo7ooSu8mEdHtjyTVBxeP1SXl4eupkWA5uFN8DeWsGuJKkiS4NDV7VZg6r06DLNvcX3wXDMEwow1VLTPNSSaqv/umZUqXaIdlnywHX6D8vM11UFCkxGgqi3dEej+d+jWx4ll/HNVQAX8xxlpoPX4DkmDSEGkJXR5FZE3/ho7CQkaLR78ij2qz4KPoeGIrqX6aJUJTf7ucMwzCRbMj89ttvuOGGG9CpUyckJiaic+fOmDlzJurrG0tTiQMHDmD8+PFITk5GVlYW7rjjDq9tmDCmqqRJ2/ltOUAqvzExIlyihEJBMQ1JWmkg6pggvBM7EpX7c+1k+XSMaD8cjgP/gN2arL1vtfpv+a7EX3C9Oh6Gm0uQztZ9vFAqXleorekieWnGVlWjoaYL8tKS/PaOYhiGifjQ0p49e2C32/Hiiy+iS5cu2LVrF2666SZUVVXhscceE9vYbDaMGzcO2dnZWL9+PUpLSzFp0iShqPr0008316ExLUlydpO2091ywMMb4cyRoaqoE0UXI779W/pzUDT258QBVBzCns0rUFQOxNj/KEJR7oZLLkTOifslKm/sfqrvgMi3ItJ9Nc5B2Ey2JDxWcTceOj8HXTt3ESXwy3cXY/a8NaK03IwYrI/P8KrEkn9ehcjE6DEXY9KwLuyJYRgmbGg2j8yYMWPw2muvYfTo0Tj11FMxYcIE3HPPPfjwww/d26xcuRK7d+/G4sWLceaZZ2LkyJF4/PHH8fLLL4uyLCYCSGnXpO10txyQeSOkSqPZDdegofIM1B66WuR9GMFXWKqm7JB4pKRg2ne8NcFjPZVATz5e7opVNT00Qzoyw7IvFf/WcuKYLNXYlgz8mDVaCNKREUNKxZI+jlYllvLzykxNYiOGYZiwokWTfcvLy5GR0Zg8uHHjRvTq1Qv5+fnuZQUFBairq8O2bdswYsQIr33QOvqTYIMnxHF3SNZO+EVqe80OyY1do4vU+yu7tFMklV+CPAs0KEsdqsngsFb2cLVAqEB87mcwWapUbQy1/SlJTG/v/jftu3MVRFsA8uJku167IjkJTeX/zvg/DG43WHwGm34txVdHlgmDxeuYKbHZASEAmNXmL15KxRL0edzaMAUzYxchX5YDJP+8rkvxNMoYhmFCnRYzZPbu3SvCReRxkSgsLERurmcX5PT0dMTFxYl1asyZMwezZ89u9uNlgt+TSb3Sx+SzQ7LUNXrqF3fpUvl9ynoxFlovVVEMdrZAEDhiRUhIGaqRvB33HvXWYnEfa2o+ug8qQLuvvkRhea04o632HqK30VmysE1TNGeEMRWXhtv63Obuc2RJ+g3mmGrt15DzJ7ZcbLdln8VDqVgOGSur6vpjoHmP0JchFeMt9u5wwIx2ac6KMYZhmIgOLc2aNUt06/X1980333i85vDhwyLUdNlll+HGG2/0WKfsBEyIrsMaLvkZM2YIz470d/DgQaOnwLRaT6ZGz5vbE6OjQzK1EVjQ4ybkKIwD8pwoS6832Hu5jZi2SbHiT056Ugza2M5UDTfR8+6HB2NUTY0oXfbE9XzMXFEFRBU90lK1sI3QnLFavTqCeyUDq3YMB6addoVHs8ZjtUd9fkby7bz7WHlCx7vJ3gNL7UPFIxkxBFcpMQwTFR6Z22+/HVdeeaXPbU455RQPI4ZCREOGDMFLL73ksV1eXh42b97ssaysrAwNDQ1enhqJ+Ph48ceEGU3skDzyrMkYse55bK8vRonF7A7hWBTJquRdkCivbhCPd43silOyktwaNat2F+LWxQ2oruwBs6vjNjVWtFd3wjcwY8eIc3DmD3M9w2FkhJHnyGV0UUUPVfZQCIe8H1LYZm7sy0hHlTiu6aVlmJqTpepJInMlyeFAtdlzLpFmt2NmtfN8A8oVSsqG1WEsPOQpQMgwDBNeNGuvpUOHDgkj5qyzzhIJvRZFJch//vMfXHjhhfj999/Rrp3zJvruu++KyqXi4mKkpqa2WK8GJoxaHQgaL1shA+eAMCSkvBgPwb20BKyfdr5HEuvyXUfcRgjtgfJn0lNr8ZdBZ+CWQaOcBpIOo4vyUajpJHlByFDqb/8esf++2L1+dVKil+BcW5sNxyUDRhHbomcLuvwZI4fNULyPDQUfFKC4ulhVU4cqmyiXaPkly4Wjddi8Ne7Ql/e2QEZyHO4fdzry0hK9BAgZhmFagmCN381myJAn5rzzzkPHjh2xaNEiDyOGPDFS+XXfvn2F92X+/Pk4duwYrrvuOlx88cW6y6/ZkIkyVJpPHnZ4Jveq8fZNg4XYntIIeWHrx3hr71OoaDjq1W2aQloBtWRY2AuoICFA50+LAmJSW4BMmx1/z8n2aIQph5bmJuUJg0QeWiJW71+NqV9MFf+WGzNSU0kS6pOOmQw1qlpybuu5f4J1YhiGaW1CvmkklVb/8ssvWLNmDU466SThcZH+JMi4+fzzz5GQkICzzz4bl19+uTBiJJ0ZJsogI2DfOmDnEucjPVdCoZ0pu4BJnwGXvIL1Z7+OYXVP+jRiCLW8kbUH/4sX98z0MGLEttXFwmAgwyHg5GaBycOIybbZhVGhZcQQtL6wulAIAarmCg1fgJykHI/lZHjJjRh56Iu8UXLoORsxDMNEEs0aWmoJ2CMTuZ4WZ17KPJ/JwKRaO/HlTX53r/TISKEaLdVgeahG6RnRxe6lotHlXEWjy1RLIips3o0dlcw7Zx7GnjpWdR0dOxk6JBZIOTFUnq11jMrQF4eRGIaJtPGbm0YyIZT7orCpKTxDy31UNtHATGXDvvJB8lTKiv22PoDD7RkZkDfA8ClpNbrUY8T4S+4lo0XvMVHuizKkxjAME0lw00imdaHwEXliVM2Qxv5GqmEm10AtL4WWIz1XKyvW3fpA53ZyfDW69Ad5gvKS8oSXhWEYhvEPGzJM60KVQb5Uf139jcR2GgSSD2KknNko/rw9WkhJu9MGTgssnMUwDBOFcGiJaV2ovDkI25GxMqpHnu58EN2tD0oPAQZDS3q9OGlxaSivL3c/p+MhIyagaimGYZgohQ0ZpnUhjZYgbWckH0S0Phhwn6hOIlNHvfXBcVhW/A04fbxu4T4jXpzHhz8Os8msK2mXYRiGUYcNGaZ5odwWX8Jy7qaSjborav2NtJpKNoWRjkTR4kApWEeeGOrf5Gx9UO08/k7n+NyXvDooq83JLm+Pb/G6/rn92XBhGIZpImzIMK1bUu3RVFL4RlT7GxnxiOjmRJEwVkZU18i0XjxbH0jb+cJTJdhJdu5YODJeE0aLmngd58EwDMMEB072ZZq3pFqZyCuVVNN6r6aSiqRcMnp0NJUMGFe4ioyWAbV1GFtVLR4tBsJakoKustv00aJuqPn9aqTGZvoVr2MYhmEChz0yTCuUVJucJdXURFLytDSxqWRANDGsReEk8sRonaWtshes+/vh5Ulpois158EwDMMEHzZkmNYtqZbnnpDR4icXJag0MaxFOTFKT4xXu4HyejhqOmNsZ98tFBiGYZjA4NASE7Il1S1CE8Jaav2bmrIdwzAMYxz2yDAhXVLdIgQY1iKtGj3o3Y5hGIYxDhsyTPBpxZLqgAkgrBVonyeGYRgmeHBoiWm+3BNfHZCaq6S6BQm0zxPDMAwTPNiQYZqH1iqpbmEC6fPEMAzDBA+Tw+HSYw9TKioqkJaWhvLycqSmprb24TBGlX0jBLmyr78+TwzDMAyCNn5zjgzTvLR0SXUrYaTPE8MwDBM8OLTEMAzDMEzYwoYMwzAMwzBhCxsyDMMwDMOELWzIMAzDMAwTtrAhwzAMwzBM2MKGDMMwDMMwYQsbMgzDMAzDhC1syDAMwzAME7awIcMwDMMwTNgS9sq+UocFkjpmGIZhGCY8kMbtpnZKCntDprKyUjx26NChtQ+FYRiGYZgAxnHquRS1TSPtdjsOHz6MlJQUmEwmn5YfGTsHDx6MmuaS0XbO0Xa+0XjO0Xa+BJ9z5H/P0fwd7969G926dYPZbI5ejwyd/EknnaR7e7pIouVCidZzjrbzjcZzjrbzJficI59o/I7bt2/fJCOG4GRfhmEYhmHCFjZkGIZhGIYJW6LGkImPj8fMmTPFY7QQbeccbecbjeccbedL8DlHPvwdN42wT/ZlGIZhGCZ6iRqPDMMwDMMwkQcbMgzDMAzDhC1syDAMwzAME7awIcMwDMMwTNgSFYbMKaecIlR/5X/Tp0/32ObAgQMYP348kpOTkZWVhTvuuAP19fUIZ+rq6tC3b19xvjt27Ijo850wYQI6duyIhIQEtGvXDtdcc41QfI7Uc/7tt99www03oFOnTkhMTETnzp1FNY/yfCLpnP/5z39i6NChSEpKQtu2bVW3iaTzJZ577jnxHdN1fdZZZ2HdunWIFL766ivxXeXn54t71Mcff+yxnupQZs2aJdbTNT58+HD88MMPCFfmzJmDAQMGCBX6nJwcXHzxxfjpp58i+pyff/55nHHGGW6hvyFDhuA///lP0M83KgwZ4sEHH8SRI0fcf/fff797nc1mw7hx41BVVYX169fjnXfewQcffIC7774b4cx9990nLhAlkXi+I0aMwHvvvSduDHQue/fuxaWXXhqx57xnzx7RnuPFF18UP/wnnngCL7zwAv72t79F7DmTQXLZZZfh1ltvVV0faef77rvvYsqUKfj73/+Ob7/9Fueccw7+8Ic/CGMtEqDvqU+fPnjmmWdU1z/66KNYsGCBWL9161bk5eVh1KhR7v564caXX36JyZMnY9OmTVi1ahWsVitGjx4tPodIPeeTTjoJc+fOxTfffCP+zj//fFx00UVuYyVo5+uIAk4++WTHE088obl+2bJlDrPZ7Dh06JB72dtvv+2Ij493lJeXO8IROqfu3bs7fvjhByqvd3z77bcRfb5KPvnkE4fJZHLU19dHzTk/+uijjk6dOrmfR+o5v/baa460tDSv5ZF2vgMHDnTccsstHsvoNz19+nRHpEH3qI8++sj93G63O/Ly8hxz5851L6utrRXf+wsvvOCIBIqLi8V5f/nll1FzzkR6errjX//6V1DPN2o8MvPmzUNmZqYItZCLWu5u3rhxI3r16uXhvSgoKBChmW3btiHcKCoqwk033YQ333xTuOGVRNr5Kjl27Bj+/e9/izBEbGxsVJwzUV5ejoyMDPfzaDhnOZF0vnR/omOmGbscer5hwwZEOvv27UNhYaHH+ZNo3HnnnRcx50+/V0L6zUb6OdtsNuElJQ8UhZiCeb5RYcjceeed4gNcu3Ytbr/9dixcuBC33Xabez19mLm5uR6vSU9PR1xcnFgXTtDk5rrrrsMtt9yC/v37q24TSecrZ9q0aSI3ggxWcr9/8sknEX/OEhRKe/rpp8X3Hi3nrCSSzvfo0aPixq88H3oebucSCNI5Rur503166tSpGDZsmDC+I/mcd+7ciTZt2ggjhe5PH330EXr06BHU8w1bQ4YShJQJvMo/iskRd911l7DyKOnoxhtvFLkEr7zyCkpLS937o+3VLja15aF8vjSYUXv0GTNm+NxfqJ+v0e+YuPfee0UuwcqVK2GxWHDttdeKc4rkcyYoqXnMmDEif4Subzmhfs6BnK8vQv18jaI87nA+l0CI1POnCfX333+Pt99+O+LPuVu3bqLYhHKDKL9t0qRJ2L17d1DPNwZhfCFceeWVfquV1Bg8eLB4/OWXX8TsnRKMNm/e7LFNWVkZGhoavKzFUD/fhx9+WFwwyl405J3585//jDfeeCMszjeQ75iqVOiva9euOP3009GhQwfxWZAbM1LPmYwYSnSmc3zppZc8tguHc27K71hJOJyvXug6JmNcOTMtLi4Ou3MJBPouCTp/qkKMpPP/61//iqVLl4qqLUqGjfRzjouLQ5cuXdzjECX1Pvnkk8KDHrTzdUQhn376qUiy2r9/v0eS4OHDh93bvPPOO2GZJEjntHPnTvffihUrxLkuWbLEcfDgwYg7Xy0OHDggznvt2rURe86///6747TTTnNceeWVDqvV6rU+Es9ZT7JvpJwvJfveeuutHstOP/30qEr2nTdvnntZXV1dWCe+0jlNnjzZkZ+f7/j5559V10faOatx/vnnOyZNmhTU8414Q2bDhg2OBQsWiKqdX3/91fHuu++KC2nChAnubWgQ6NWrl+OCCy5wbN++3bF69WrHSSed5Lj99tsd4c6+ffu8qpYi7Xw3b97sePrpp8U5/vbbb441a9Y4hg0b5ujcubPIgo/Ec6bKnC5duoibAhk0R44ccf9JRNo5k5FO3/Hs2bMdbdq0Ef+mv8rKyog8XzLCYmNjHa+88opj9+7djilTpjiSk5PFNR4J0PcmfYd0j5Lu09IEk6pZaFD78MMPxaRs4sSJjnbt2jkqKioc4QgZpXQ+X3zxhcfvtbq62r1NpJ3zjBkzHF999ZUYh77//nvH3/72NzHZWLlyZVDPN+INmW3btjkGDRokPqyEhARHt27dHDNnznRUVVV5bEc/nnHjxjkSExMdGRkZ4uYnDYKRZshE2vnSD2TEiBHiPGj2fcopp4iyVRrgI/WcyStB36vaX6SeM83i1M5X8rpF2vkSzz77rJCPiIuLc/Tr189dqhsJ0Pem9n3S90zQjJ3u1TRrp9/1ueeeKwa7cEXr90q/ZYlIO+frr7/eff1mZ2eLSYZkxATzfE30n+BGxBiGYRiGYVqGsK1aYhiGYRiGYUOGYRiGYZiwhQ0ZhmEYhmHCFjZkGIZhGIYJW9iQYRiGYRgmbGFDhmEYhmGYsIUNGYZhGIZhwhY2ZBiGYRiGCVvYkGEYhmEYJmxhQ4ZhGIZhmLCFDRmGYRiGYcIWNmQYhmEYhkG48v8/uLw0uayDUgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for cloud in clouds[:3]:\n",
    "    plt.scatter(cloud[:,0],cloud[:,1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Spheres"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "THETA = [30,40,50,60,70]\n",
    "K = [0.0001,0.001,0.01,0.1,0.25,0.5]\n",
    "ALPHA = [1,4,8]\n",
    "\n",
    "C = [100,200] #Size of the Forest\n",
    "\n",
    "params = [THETA,K,ALPHA,C]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0.9698590305769141 {'n_theta': 70, 'alpha': 8, 'k': 0.25, 'model': RandomForestRegressor(n_estimators=200), 'idx_model': 1}\n",
      "1\n",
      "0.9676859311637697 {'n_theta': 50, 'alpha': 8, 'k': 0.25, 'model': RandomForestRegressor(n_estimators=200), 'idx_model': 1}\n",
      "2\n",
      "0.9688224692517311 {'n_theta': 70, 'alpha': 8, 'k': 0.25, 'model': RandomForestRegressor(n_estimators=200), 'idx_model': 1}\n",
      "3\n",
      "0.9651035055762879 {'n_theta': 60, 'alpha': 8, 'k': 0.25, 'model': RandomForestRegressor(n_estimators=200), 'idx_model': 1}\n",
      "4\n",
      "0.9607524370702472 {'n_theta': 50, 'alpha': 1, 'k': 0.6, 'model': RandomForestRegressor(), 'idx_model': 0}\n",
      "5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Process SpawnPoolWorker-56:\n",
      "Traceback (most recent call last):\n",
      "Process SpawnPoolWorker-53:\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 313, in _bootstrap\n",
      "    self.run()\n",
      "    ~~~~~~~~^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 108, in run\n",
      "    self._target(*self._args, **self._kwargs)\n",
      "    ~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 125, in worker\n",
      "    result = (True, func(*args, **kwds))\n",
      "                    ~~~~^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 48, in mapstar\n",
      "    return list(map(*args))\n",
      "  File \"/Users/ye72al/Library/CloudStorage/GoogleDrive-matteopego.91@gmail.com/My Drive/ICLR_2026/Review_Submission/pipelines_utils.py\", line 42, in make_CV_fold\n",
      "    model.fit(train_data,train_y)\n",
      "    ~~~~~~~~~^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/base.py\", line 1365, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 486, in fit\n",
      "    trees = Parallel(\n",
      "    ...<2 lines>...\n",
      "        prefer=\"threads\",\n",
      "    )(\n",
      "        delayed(_parallel_build_trees)(\n",
      "    ...<12 lines>...\n",
      "        for i, t in enumerate(trees)\n",
      "    )\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 82, in __call__\n",
      "    return super().__call__(iterable_with_config_and_warning_filters)\n",
      "           ~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1986, in __call__\n",
      "    return output if self.return_generator else list(output)\n",
      "                                                ~~~~^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1914, in _get_sequential_output\n",
      "    res = func(*args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 147, in __call__\n",
      "    return self.function(*args, **kwargs)\n",
      "           ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 188, in _parallel_build_trees\n",
      "    tree._fit(\n",
      "    ~~~~~~~~~^\n",
      "        X,\n",
      "        ^^\n",
      "    ...<3 lines>...\n",
      "        missing_values_in_feature_mask=missing_values_in_feature_mask,\n",
      "        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "    )\n",
      "    ^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/tree/_classes.py\", line 472, in _fit\n",
      "    builder.build(self.tree_, X, y, sample_weight, missing_values_in_feature_mask)\n",
      "    ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "KeyboardInterrupt\n",
      "Traceback (most recent call last):\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 313, in _bootstrap\n",
      "    self.run()\n",
      "    ~~~~~~~~^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 108, in run\n",
      "    self._target(*self._args, **self._kwargs)\n",
      "    ~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 125, in worker\n",
      "    result = (True, func(*args, **kwds))\n",
      "                    ~~~~^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 48, in mapstar\n",
      "    return list(map(*args))\n",
      "  File \"/Users/ye72al/Library/CloudStorage/GoogleDrive-matteopego.91@gmail.com/My Drive/ICLR_2026/Review_Submission/pipelines_utils.py\", line 42, in make_CV_fold\n",
      "    model.fit(train_data,train_y)\n",
      "    ~~~~~~~~~^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/base.py\", line 1365, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 486, in fit\n",
      "    trees = Parallel(\n",
      "    ...<2 lines>...\n",
      "        prefer=\"threads\",\n",
      "    )(\n",
      "        delayed(_parallel_build_trees)(\n",
      "    ...<12 lines>...\n",
      "        for i, t in enumerate(trees)\n",
      "    )\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 82, in __call__\n",
      "    return super().__call__(iterable_with_config_and_warning_filters)\n",
      "           ~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1986, in __call__\n",
      "    return output if self.return_generator else list(output)\n",
      "                                                ~~~~^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1914, in _get_sequential_output\n",
      "    res = func(*args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 147, in __call__\n",
      "    return self.function(*args, **kwargs)\n",
      "           ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 188, in _parallel_build_trees\n",
      "    tree._fit(\n",
      "    ~~~~~~~~~^\n",
      "        X,\n",
      "        ^^\n",
      "    ...<3 lines>...\n",
      "        missing_values_in_feature_mask=missing_values_in_feature_mask,\n",
      "        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "    )\n",
      "    ^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/tree/_classes.py\", line 472, in _fit\n",
      "    builder.build(self.tree_, X, y, sample_weight, missing_values_in_feature_mask)\n",
      "    ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "KeyboardInterrupt\n",
      "Process SpawnPoolWorker-54:\n",
      "Process SpawnPoolWorker-52:\n",
      "Traceback (most recent call last):\n",
      "Process SpawnPoolWorker-57:\n",
      "Traceback (most recent call last):\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 313, in _bootstrap\n",
      "    self.run()\n",
      "    ~~~~~~~~^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 108, in run\n",
      "    self._target(*self._args, **self._kwargs)\n",
      "    ~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 125, in worker\n",
      "    result = (True, func(*args, **kwds))\n",
      "                    ~~~~^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 48, in mapstar\n",
      "    return list(map(*args))\n",
      "  File \"/Users/ye72al/Library/CloudStorage/GoogleDrive-matteopego.91@gmail.com/My Drive/ICLR_2026/Review_Submission/pipelines_utils.py\", line 42, in make_CV_fold\n",
      "    model.fit(train_data,train_y)\n",
      "    ~~~~~~~~~^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/base.py\", line 1365, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 486, in fit\n",
      "    trees = Parallel(\n",
      "    ...<2 lines>...\n",
      "        prefer=\"threads\",\n",
      "    )(\n",
      "        delayed(_parallel_build_trees)(\n",
      "    ...<12 lines>...\n",
      "        for i, t in enumerate(trees)\n",
      "    )\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 82, in __call__\n",
      "    return super().__call__(iterable_with_config_and_warning_filters)\n",
      "           ~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1986, in __call__\n",
      "    return output if self.return_generator else list(output)\n",
      "                                                ~~~~^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1914, in _get_sequential_output\n",
      "    res = func(*args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 147, in __call__\n",
      "    return self.function(*args, **kwargs)\n",
      "           ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 188, in _parallel_build_trees\n",
      "    tree._fit(\n",
      "    ~~~~~~~~~^\n",
      "        X,\n",
      "        ^^\n",
      "    ...<3 lines>...\n",
      "        missing_values_in_feature_mask=missing_values_in_feature_mask,\n",
      "        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "    )\n",
      "    ^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/tree/_classes.py\", line 472, in _fit\n",
      "    builder.build(self.tree_, X, y, sample_weight, missing_values_in_feature_mask)\n",
      "    ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "KeyboardInterrupt\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 313, in _bootstrap\n",
      "    self.run()\n",
      "    ~~~~~~~~^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 108, in run\n",
      "    self._target(*self._args, **self._kwargs)\n",
      "    ~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 125, in worker\n",
      "    result = (True, func(*args, **kwds))\n",
      "                    ~~~~^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 48, in mapstar\n",
      "    return list(map(*args))\n",
      "  File \"/Users/ye72al/Library/CloudStorage/GoogleDrive-matteopego.91@gmail.com/My Drive/ICLR_2026/Review_Submission/pipelines_utils.py\", line 42, in make_CV_fold\n",
      "    model.fit(train_data,train_y)\n",
      "    ~~~~~~~~~^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/base.py\", line 1365, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 486, in fit\n",
      "    trees = Parallel(\n",
      "    ...<2 lines>...\n",
      "        prefer=\"threads\",\n",
      "    )(\n",
      "        delayed(_parallel_build_trees)(\n",
      "    ...<12 lines>...\n",
      "        for i, t in enumerate(trees)\n",
      "    )\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 82, in __call__\n",
      "    return super().__call__(iterable_with_config_and_warning_filters)\n",
      "           ~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1986, in __call__\n",
      "    return output if self.return_generator else list(output)\n",
      "                                                ~~~~^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1914, in _get_sequential_output\n",
      "    res = func(*args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 147, in __call__\n",
      "    return self.function(*args, **kwargs)\n",
      "           ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 188, in _parallel_build_trees\n",
      "    tree._fit(\n",
      "    ~~~~~~~~~^\n",
      "        X,\n",
      "        ^^\n",
      "    ...<3 lines>...\n",
      "        missing_values_in_feature_mask=missing_values_in_feature_mask,\n",
      "        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "    )\n",
      "    ^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/tree/_classes.py\", line 472, in _fit\n",
      "    builder.build(self.tree_, X, y, sample_weight, missing_values_in_feature_mask)\n",
      "    ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "KeyboardInterrupt\n",
      "Process SpawnPoolWorker-51:\n",
      "Traceback (most recent call last):\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 313, in _bootstrap\n",
      "    self.run()\n",
      "    ~~~~~~~~^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 108, in run\n",
      "    self._target(*self._args, **self._kwargs)\n",
      "    ~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 125, in worker\n",
      "    result = (True, func(*args, **kwds))\n",
      "                    ~~~~^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 48, in mapstar\n",
      "    return list(map(*args))\n",
      "  File \"/Users/ye72al/Library/CloudStorage/GoogleDrive-matteopego.91@gmail.com/My Drive/ICLR_2026/Review_Submission/pipelines_utils.py\", line 42, in make_CV_fold\n",
      "    model.fit(train_data,train_y)\n",
      "    ~~~~~~~~~^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/base.py\", line 1365, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 486, in fit\n",
      "    trees = Parallel(\n",
      "    ...<2 lines>...\n",
      "        prefer=\"threads\",\n",
      "    )(\n",
      "        delayed(_parallel_build_trees)(\n",
      "    ...<12 lines>...\n",
      "        for i, t in enumerate(trees)\n",
      "    )\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 82, in __call__\n",
      "    return super().__call__(iterable_with_config_and_warning_filters)\n",
      "           ~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1986, in __call__\n",
      "    return output if self.return_generator else list(output)\n",
      "                                                ~~~~^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1914, in _get_sequential_output\n",
      "    res = func(*args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 147, in __call__\n",
      "    return self.function(*args, **kwargs)\n",
      "           ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 188, in _parallel_build_trees\n",
      "    tree._fit(\n",
      "    ~~~~~~~~~^\n",
      "        X,\n",
      "        ^^\n",
      "    ...<3 lines>...\n",
      "        missing_values_in_feature_mask=missing_values_in_feature_mask,\n",
      "        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "    )\n",
      "    ^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/tree/_classes.py\", line 472, in _fit\n",
      "    builder.build(self.tree_, X, y, sample_weight, missing_values_in_feature_mask)\n",
      "    ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "KeyboardInterrupt\n",
      "Traceback (most recent call last):\n",
      "Process SpawnPoolWorker-59:\n",
      "Traceback (most recent call last):\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 313, in _bootstrap\n",
      "    self.run()\n",
      "    ~~~~~~~~^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 108, in run\n",
      "    self._target(*self._args, **self._kwargs)\n",
      "    ~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 313, in _bootstrap\n",
      "    self.run()\n",
      "    ~~~~~~~~^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 108, in run\n",
      "    self._target(*self._args, **self._kwargs)\n",
      "    ~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 125, in worker\n",
      "    result = (True, func(*args, **kwds))\n",
      "                    ~~~~^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 48, in mapstar\n",
      "    return list(map(*args))\n",
      "  File \"/Users/ye72al/Library/CloudStorage/GoogleDrive-matteopego.91@gmail.com/My Drive/ICLR_2026/Review_Submission/pipelines_utils.py\", line 42, in make_CV_fold\n",
      "    model.fit(train_data,train_y)\n",
      "    ~~~~~~~~~^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/base.py\", line 1365, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 486, in fit\n",
      "    trees = Parallel(\n",
      "    ...<2 lines>...\n",
      "        prefer=\"threads\",\n",
      "    )(\n",
      "        delayed(_parallel_build_trees)(\n",
      "    ...<12 lines>...\n",
      "        for i, t in enumerate(trees)\n",
      "    )\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 82, in __call__\n",
      "    return super().__call__(iterable_with_config_and_warning_filters)\n",
      "           ~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1986, in __call__\n",
      "    return output if self.return_generator else list(output)\n",
      "                                                ~~~~^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1914, in _get_sequential_output\n",
      "    res = func(*args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 147, in __call__\n",
      "    return self.function(*args, **kwargs)\n",
      "           ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 188, in _parallel_build_trees\n",
      "    tree._fit(\n",
      "    ~~~~~~~~~^\n",
      "        X,\n",
      "        ^^\n",
      "    ...<3 lines>...\n",
      "        missing_values_in_feature_mask=missing_values_in_feature_mask,\n",
      "        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "    )\n",
      "    ^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/tree/_classes.py\", line 472, in _fit\n",
      "    builder.build(self.tree_, X, y, sample_weight, missing_values_in_feature_mask)\n",
      "    ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "KeyboardInterrupt\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 125, in worker\n",
      "    result = (True, func(*args, **kwds))\n",
      "                    ~~~~^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 48, in mapstar\n",
      "    return list(map(*args))\n",
      "  File \"/Users/ye72al/Library/CloudStorage/GoogleDrive-matteopego.91@gmail.com/My Drive/ICLR_2026/Review_Submission/pipelines_utils.py\", line 42, in make_CV_fold\n",
      "    model.fit(train_data,train_y)\n",
      "    ~~~~~~~~~^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/base.py\", line 1365, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 486, in fit\n",
      "    trees = Parallel(\n",
      "    ...<2 lines>...\n",
      "        prefer=\"threads\",\n",
      "    )(\n",
      "        delayed(_parallel_build_trees)(\n",
      "    ...<12 lines>...\n",
      "        for i, t in enumerate(trees)\n",
      "    )\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 82, in __call__\n",
      "    return super().__call__(iterable_with_config_and_warning_filters)\n",
      "           ~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1986, in __call__\n",
      "    return output if self.return_generator else list(output)\n",
      "                                                ~~~~^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1914, in _get_sequential_output\n",
      "    res = func(*args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 147, in __call__\n",
      "    return self.function(*args, **kwargs)\n",
      "           ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 188, in _parallel_build_trees\n",
      "    tree._fit(\n",
      "    ~~~~~~~~~^\n",
      "        X,\n",
      "        ^^\n",
      "    ...<3 lines>...\n",
      "        missing_values_in_feature_mask=missing_values_in_feature_mask,\n",
      "        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "    )\n",
      "    ^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/tree/_classes.py\", line 472, in _fit\n",
      "    builder.build(self.tree_, X, y, sample_weight, missing_values_in_feature_mask)\n",
      "    ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "KeyboardInterrupt\n",
      "Process SpawnPoolWorker-60:\n",
      "Traceback (most recent call last):\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 313, in _bootstrap\n",
      "    self.run()\n",
      "    ~~~~~~~~^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/process.py\", line 108, in run\n",
      "    self._target(*self._args, **self._kwargs)\n",
      "    ~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 125, in worker\n",
      "    result = (True, func(*args, **kwds))\n",
      "                    ~~~~^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py\", line 48, in mapstar\n",
      "    return list(map(*args))\n",
      "  File \"/Users/ye72al/Library/CloudStorage/GoogleDrive-matteopego.91@gmail.com/My Drive/ICLR_2026/Review_Submission/pipelines_utils.py\", line 42, in make_CV_fold\n",
      "    model.fit(train_data,train_y)\n",
      "    ~~~~~~~~~^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/base.py\", line 1365, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 486, in fit\n",
      "    trees = Parallel(\n",
      "    ...<2 lines>...\n",
      "        prefer=\"threads\",\n",
      "    )(\n",
      "        delayed(_parallel_build_trees)(\n",
      "    ...<12 lines>...\n",
      "        for i, t in enumerate(trees)\n",
      "    )\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 82, in __call__\n",
      "    return super().__call__(iterable_with_config_and_warning_filters)\n",
      "           ~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1986, in __call__\n",
      "    return output if self.return_generator else list(output)\n",
      "                                                ~~~~^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/joblib/parallel.py\", line 1914, in _get_sequential_output\n",
      "    res = func(*args, **kwargs)\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/utils/parallel.py\", line 147, in __call__\n",
      "    return self.function(*args, **kwargs)\n",
      "           ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/ensemble/_forest.py\", line 188, in _parallel_build_trees\n",
      "    tree._fit(\n",
      "    ~~~~~~~~~^\n",
      "        X,\n",
      "        ^^\n",
      "    ...<3 lines>...\n",
      "        missing_values_in_feature_mask=missing_values_in_feature_mask,\n",
      "        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "    )\n",
      "    ^\n",
      "  File \"/opt/anaconda3/envs/trees_final/lib/python3.13/site-packages/sklearn/tree/_classes.py\", line 472, in _fit\n",
      "    builder.build(self.tree_, X, y, sample_weight, missing_values_in_feature_mask)\n",
      "    ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "KeyboardInterrupt\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mKeyboardInterrupt\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[7]\u001b[39m\u001b[32m, line 10\u001b[39m\n\u001b[32m      7\u001b[39m \u001b[38;5;28mprint\u001b[39m(i)\n\u001b[32m      8\u001b[39m SPipe = SpheresPipeline(DGMS, R, [params], \n\u001b[32m      9\u001b[39m      MODELS = [\u001b[33m'\u001b[39m\u001b[33mregr_tree\u001b[39m\u001b[33m'\u001b[39m],train_split = \u001b[32m0.3\u001b[39m, n_splits = \u001b[32m3\u001b[39m)\n\u001b[32m---> \u001b[39m\u001b[32m10\u001b[39m score = \u001b[43mSPipe\u001b[49m\u001b[43m.\u001b[49m\u001b[43mrun_analysis\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m     11\u001b[39m scores_dataset[i]= score\n\u001b[32m     12\u001b[39m \u001b[38;5;28mprint\u001b[39m(score, SPipe.best_params)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/Library/CloudStorage/GoogleDrive-matteopego.91@gmail.com/My Drive/ICLR_2026/Review_Submission/pipelines.py:196\u001b[39m, in \u001b[36mSpheresPipeline.run_analysis\u001b[39m\u001b[34m(self)\u001b[39m\n\u001b[32m    194\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mrun_analysis\u001b[39m(\u001b[38;5;28mself\u001b[39m,):\n\u001b[32m--> \u001b[39m\u001b[32m196\u001b[39m     \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mparameter_selection\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    197\u001b[39m     \u001b[38;5;28mself\u001b[39m.read_CV_results()\n\u001b[32m    198\u001b[39m     score = \u001b[38;5;28mself\u001b[39m.evaluate_best_model()\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/Library/CloudStorage/GoogleDrive-matteopego.91@gmail.com/My Drive/ICLR_2026/Review_Submission/pipelines.py:109\u001b[39m, in \u001b[36mSpheresPipeline.parameter_selection\u001b[39m\u001b[34m(self)\u001b[39m\n\u001b[32m    106\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m MP:\n\u001b[32m    107\u001b[39m     pool = mp.Pool()\n\u001b[32m--> \u001b[39m\u001b[32m109\u001b[39m     \u001b[38;5;28mself\u001b[39m.RESULTS = \u001b[43mpool\u001b[49m\u001b[43m.\u001b[49m\u001b[43mmap\u001b[49m\u001b[43m(\u001b[49m\u001b[43mmake_CV_fold\u001b[49m\u001b[43m,\u001b[49m\u001b[43m(\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43my_train\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mDGMS_train\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    110\u001b[39m \u001b[43m                                         \u001b[49m\u001b[43mn_theta\u001b[49m\u001b[43m,\u001b[49m\u001b[43malpha\u001b[49m\u001b[43m,\u001b[49m\u001b[43mk\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\n\u001b[32m    111\u001b[39m \u001b[43m                                         \u001b[49m\u001b[43mmodel\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\n\u001b[32m    112\u001b[39m \u001b[43m                                         \u001b[49m\u001b[43mtrain_idx\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtest_idx\u001b[49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mn_theta\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mTHETA\u001b[49m\u001b[43m \u001b[49m\n\u001b[32m    113\u001b[39m \u001b[43m                                                              \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43malpha\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mALPHA\u001b[49m\n\u001b[32m    114\u001b[39m \u001b[43m                                                              \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mk\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mK\u001b[49m\n\u001b[32m    115\u001b[39m \u001b[43m                                                              \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mmodel\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mMODELS\u001b[49m\n\u001b[32m    116\u001b[39m \u001b[43m                                                              \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43m(\u001b[49m\u001b[43mtrain_idx\u001b[49m\u001b[43m,\u001b[49m\u001b[43mtest_idx\u001b[49m\u001b[43m)\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mCV_splits\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    118\u001b[39m     pool.close()\n\u001b[32m    120\u001b[39m \u001b[38;5;28;01melse\u001b[39;00m:\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py:367\u001b[39m, in \u001b[36mPool.map\u001b[39m\u001b[34m(self, func, iterable, chunksize)\u001b[39m\n\u001b[32m    362\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mmap\u001b[39m(\u001b[38;5;28mself\u001b[39m, func, iterable, chunksize=\u001b[38;5;28;01mNone\u001b[39;00m):\n\u001b[32m    363\u001b[39m \u001b[38;5;250m    \u001b[39m\u001b[33;03m'''\u001b[39;00m\n\u001b[32m    364\u001b[39m \u001b[33;03m    Apply `func` to each element in `iterable`, collecting the results\u001b[39;00m\n\u001b[32m    365\u001b[39m \u001b[33;03m    in a list that is returned.\u001b[39;00m\n\u001b[32m    366\u001b[39m \u001b[33;03m    '''\u001b[39;00m\n\u001b[32m--> \u001b[39m\u001b[32m367\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43m_map_async\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfunc\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43miterable\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmapstar\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mchunksize\u001b[49m\u001b[43m)\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py:768\u001b[39m, in \u001b[36mApplyResult.get\u001b[39m\u001b[34m(self, timeout)\u001b[39m\n\u001b[32m    767\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mget\u001b[39m(\u001b[38;5;28mself\u001b[39m, timeout=\u001b[38;5;28;01mNone\u001b[39;00m):\n\u001b[32m--> \u001b[39m\u001b[32m768\u001b[39m     \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mwait\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtimeout\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    769\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28mself\u001b[39m.ready():\n\u001b[32m    770\u001b[39m         \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mTimeoutError\u001b[39;00m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/trees_final/lib/python3.13/multiprocessing/pool.py:765\u001b[39m, in \u001b[36mApplyResult.wait\u001b[39m\u001b[34m(self, timeout)\u001b[39m\n\u001b[32m    764\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mwait\u001b[39m(\u001b[38;5;28mself\u001b[39m, timeout=\u001b[38;5;28;01mNone\u001b[39;00m):\n\u001b[32m--> \u001b[39m\u001b[32m765\u001b[39m     \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43m_event\u001b[49m\u001b[43m.\u001b[49m\u001b[43mwait\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtimeout\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/trees_final/lib/python3.13/threading.py:659\u001b[39m, in \u001b[36mEvent.wait\u001b[39m\u001b[34m(self, timeout)\u001b[39m\n\u001b[32m    657\u001b[39m signaled = \u001b[38;5;28mself\u001b[39m._flag\n\u001b[32m    658\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m signaled:\n\u001b[32m--> \u001b[39m\u001b[32m659\u001b[39m     signaled = \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43m_cond\u001b[49m\u001b[43m.\u001b[49m\u001b[43mwait\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtimeout\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    660\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m signaled\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/trees_final/lib/python3.13/threading.py:359\u001b[39m, in \u001b[36mCondition.wait\u001b[39m\u001b[34m(self, timeout)\u001b[39m\n\u001b[32m    357\u001b[39m \u001b[38;5;28;01mtry\u001b[39;00m:    \u001b[38;5;66;03m# restore state no matter what (e.g., KeyboardInterrupt)\u001b[39;00m\n\u001b[32m    358\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m timeout \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[32m--> \u001b[39m\u001b[32m359\u001b[39m         \u001b[43mwaiter\u001b[49m\u001b[43m.\u001b[49m\u001b[43macquire\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    360\u001b[39m         gotit = \u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[32m    361\u001b[39m     \u001b[38;5;28;01melse\u001b[39;00m:\n",
      "\u001b[31mKeyboardInterrupt\u001b[39m: "
     ]
    }
   ],
   "source": [
    "N = 5\n",
    "\n",
    "scores_dataset = np.zeros((N,))\n",
    "\n",
    "for i in range(N):\n",
    "    print(i)\n",
    "    SPipe = SpheresPipeline(DGMS, R, [params], \n",
    "         MODELS = ['regr_tree'],train_split = 0.3, n_splits = 3)\n",
    "    score = SPipe.run_analysis()\n",
    "    scores_dataset[i]= score\n",
    "    print(score, SPipe.best_params)\n",
    "    \n",
    "print(scores_dataset,np.mean(scores_dataset),np.std(scores_dataset))\n",
    "np.save('Spheres_scores_eyeglasses',scores_dataset)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Persistence Images"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "P = [1,2,4,8,10]\n",
    "N_ = [20,50,100]\n",
    "N_SIGMA = [0.1,1,10,100,1000,10000,100000,1000000] # Size of sigma w.r.t. size of the pixel\n",
    "\n",
    "C = [100,200] #Size of the Forest\n",
    "params = [C]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0.9227361100574133 {'pix': np.float64(100.0), 'sigma': np.float64(0.0001), 'p': 1, 'model': RandomForestRegressor(n_estimators=200)}\n",
      "1\n",
      "0.9036942216790406 {'pix': np.float64(100.0), 'sigma': np.float64(0.0001), 'p': 1, 'model': RandomForestRegressor(n_estimators=200)}\n",
      "2\n",
      "0.9249104343510859 {'pix': np.float64(100.0), 'sigma': np.float64(0.0001), 'p': 2, 'model': RandomForestRegressor(n_estimators=200)}\n",
      "3\n",
      "0.9285148912056029 {'pix': np.float64(100.0), 'sigma': np.float64(0.0001), 'p': 1, 'model': RandomForestRegressor(n_estimators=200)}\n",
      "4\n",
      "0.9285065577769248 {'pix': np.float64(100.0), 'sigma': np.float64(0.0001), 'p': 1, 'model': RandomForestRegressor(n_estimators=200)}\n",
      "[0.92273611 0.90369422 0.92491043 0.92851489 0.92850656] 0.9216724430140136 0.009255880721948339\n"
     ]
    }
   ],
   "source": [
    "N = 5\n",
    "\n",
    "scores_dataset = np.zeros((N,))\n",
    "\n",
    "\n",
    "for i in range(N):\n",
    "    print(i)\n",
    "\n",
    "    Pi_Pipe = PiPipeline(DGMS, R, [params], \n",
    "             MODELS = ['regr_tree'],train_split = 0.3, n_splits = 3, \n",
    "             N = N_, N_SIGMA = N_SIGMA, P = P)\n",
    "    score = Pi_Pipe.run_analysis()\n",
    "    scores_dataset[i]= score\n",
    "    print(score, Pi_Pipe.best_params)\n",
    "\n",
    "print(scores_dataset,np.mean(scores_dataset),np.std(scores_dataset))\n",
    "np.save('Pi_scores_eyeglasses',scores_dataset)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Persistence Landscapes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "C = [100,200] #Size of the Forest\n",
    "params = [C]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0.9637730848775875 {'model': RandomForestRegressor()}\n",
      "1\n",
      "0.9227460981067801 {'model': RandomForestRegressor()}\n",
      "2\n",
      "0.9499953236408095 {'model': RandomForestRegressor(n_estimators=200)}\n",
      "3\n",
      "0.9759951256469688 {'model': RandomForestRegressor()}\n",
      "4\n",
      "0.9616342982313837 {'model': RandomForestRegressor()}\n",
      "[0.96377308 0.9227461  0.94999532 0.97599513 0.9616343 ] 0.954828786100706 0.018038795048591457\n"
     ]
    }
   ],
   "source": [
    "N = 5\n",
    "\n",
    "scores_dataset = np.zeros((N,))\n",
    "\n",
    "\n",
    "for i in range(N):\n",
    "    print(i)\n",
    "    Pl_Pipe = PLPipeline(DGMS, R, [params], \n",
    "             MODELS = ['regr_tree'],train_split = 0.3, n_splits = 3)\n",
    "    score = Pl_Pipe.run_analysis()\n",
    "    scores_dataset[i]= score\n",
    "    print(score, Pl_Pipe.best_params)\n",
    "\n",
    "print(scores_dataset,np.mean(scores_dataset),np.std(scores_dataset))\n",
    "np.save('PL_scores_eyeglasses',scores_dataset)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Persistence Splines"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "H = [5,10,20,40,50]\n",
    "ITER = [5,10,50,100]\n",
    "\n",
    "C = [100,200] #Size of the Forest\n",
    "params = [C]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0.9774713646119264 {'h': 5, 'iterations': 50, 'model': RandomForestRegressor()}\n",
      "1\n",
      "0.94871849635357 {'h': 10, 'iterations': 100, 'model': RandomForestRegressor(n_estimators=200)}\n",
      "2\n",
      "0.9742835018016216 {'h': 5, 'iterations': 50, 'model': RandomForestRegressor()}\n",
      "3\n",
      "0.978985055220424 {'h': 5, 'iterations': 5, 'model': RandomForestRegressor(n_estimators=200)}\n",
      "4\n",
      "0.9753976217165438 {'h': 5, 'iterations': 50, 'model': RandomForestRegressor(n_estimators=200)}\n",
      "[0.97747136 0.9487185  0.9742835  0.97898506 0.97539762] 0.9709712079408173 0.011244744438975022\n"
     ]
    }
   ],
   "source": [
    "N = 5\n",
    "\n",
    "scores_dataset = np.zeros((N,))\n",
    "\n",
    "\n",
    "for i in range(N):\n",
    "    print(i)\n",
    "    SplPipe = PersSplinesPipeline(DGMS, R, [params],  \n",
    "             MODELS = ['regr_tree'],train_split = 0.3, n_splits = 3, \n",
    "             H = H, ITER = ITER)\n",
    "    score = SplPipe.run_analysis()\n",
    "    scores_dataset[i]= score\n",
    "    print(score, SplPipe.best_params)\n",
    "    \n",
    "print(scores_dataset,np.mean(scores_dataset),np.std(scores_dataset))\n",
    "np.save('PSpl_scores_eyeglasses',scores_dataset)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Sliced Wasserstein Kernel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "SIGMA = [0.00001, 0.0001, 0.001, 0.01, 0.1, 1, 10]\n",
    "C = [0.001, 0.01, 0.1, 1, 10, 100,1000]\n",
    "\n",
    "params = [SIGMA,C]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "Making Graham Matrix.\n",
      "Done! 4066.68887090683\n",
      "0.9763968395600846 {'sigma': 10, 'model': SVR(C=100, max_iter=100000)}\n",
      "1\n",
      "Making Graham Matrix.\n",
      "Done! 3977.2420160770416\n",
      "0.973491417140938 {'sigma': 10, 'model': SVR(C=100, max_iter=100000)}\n",
      "2\n",
      "Making Graham Matrix.\n",
      "Done! 4022.815531015396\n",
      "0.968435451094309 {'sigma': 10, 'model': SVR(C=100, max_iter=100000)}\n",
      "3\n",
      "Making Graham Matrix.\n",
      "Done! 4021.188967227936\n",
      "0.9685833279056124 {'sigma': 10, 'model': SVR(C=1000, max_iter=100000)}\n",
      "4\n",
      "Making Graham Matrix.\n",
      "Done! 3947.0128700733185\n",
      "0.9697352958900957 {'sigma': 10, 'model': SVR(C=100, max_iter=100000)}\n",
      "[0.97639684 0.97349142 0.96843545 0.96858333 0.9697353 ] 0.971328466318208 0.0031244288304760706\n"
     ]
    }
   ],
   "source": [
    "N = 5\n",
    "\n",
    "scores_dataset = np.zeros((N,))\n",
    "\n",
    "\n",
    "for i in range(N):\n",
    "    print(i)\n",
    "    KPipe = KernelPipeline(DGMS, R, params,D=None, \n",
    "         model = 'SVR',train_split = 0.3, n_splits = 3, \n",
    "         M=50)\n",
    "    score = KPipe.run_analysis()\n",
    "    scores_dataset[i]= score\n",
    "    print(score, KPipe.best_params)\n",
    "\n",
    "print(scores_dataset,np.mean(scores_dataset),np.std(scores_dataset))\n",
    "np.save('Kernel_scores_eyeglasses',scores_dataset)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.13.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
