{
	"cells": [
		{
			"cell_type": "code",
			"execution_count": 1,
			"metadata": {},
			"outputs": [],
			"source": [
				"import os\n",
				"import numpy as np\n",
				"import matplotlib.pyplot as plt\n",
				"from collections import defaultdict\n",
				"import math\n",
				"import torch"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 27,
			"metadata": {},
			"outputs": [
				{
					"data": {
						"image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAHqCAYAAAAZLi26AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAdZhJREFUeJzt3Xt8zvX/x/HndV07m41pNmPM+TjkmCTJMlIRCl/ZSIdvpUg6UDmkUjohJR0cKpWo1LcDMYeKhRzKmZyV2Zhhw8auz+8Pv33s2q6xsY/L4XG/3a5bXa/P+/p83q/PPp+363V9TjbDMAwBAAAAAIBiZ/d0BwAAAAAAuFJRdAMAAAAAYBGKbgAAAAAALELRDQAAAACARSi6AQAAAACwCEU3AAAAAAAWoegGAAAAAMAiFN0AAAAAAFiEohsAAAAAAItQdAOwRJ8+fRQYGOjpbhSbqVOnymazaefOnRd92VFRUerTp89FX+75GDFihGw2m6e7ccF27twpm82mqVOnerorHmfF9mez2TRixIhinee5XE7bZk5fDxw44OmuXDZuuukm3XTTTZ7uhkd4Yn+SLq99CvA0im7gMpdTDP7xxx8FtskpIHJe3t7euuaaa3T99ddr6NCh2r17d4Gf69u3r6pWrSo/Pz+Fh4frxhtv1PDhw61Kp8iioqJccitbtqxatWqlb775xtNdK5KlS5dqxIgRSktL83RXTDnbVs7Lz89PERERio2N1fjx43X06FFPd/Gqc/LkSY0fP15NmzZVyZIlFRgYqKZNm2r8+PE6efLkec/3Utz+PKVPnz6y2WwKCgrS8ePH803funWruU+8/vrrHuihZ+UUWrn/PYmKitJjjz3G9pNL3vUUEBCgOnXq6LnnntORI0c83b1CO3bsmEaMGKFFixZ5uivAZc3L0x0AcPH07NlTt956q5xOpw4dOqQVK1Zo7NixGjdunD766CP16NHDbPv333+radOm8vf317333quoqCjt27dPq1at0quvvqqRI0d6MBNXDRs21BNPPCFJ+vfffzVp0iR16dJFEydO1H//+99iWUbv3r3Vo0cP+fr6Fsv88lq6dKlGjhypPn36qFSpUi7TNm/eLLvdc7+RvvDCC6pcubJOnjyppKQkLVq0SAMHDtSbb76p7777TvXr1zfbPvfcc3rmmWc81tfiUqlSJR0/flze3t6e7oopIyNDHTt21OLFi3XbbbepT58+stvtmjNnjgYMGKCvv/5aP/zwg0qUKFHkeV/s7e/48ePy8rp0v4J4eXnp2LFj+t///qe7777bZdr06dPl5+enEydOeKh3l4aJEycqMDBQGRkZSkhI0Ntvv61Vq1bpt99+83TXLik56yk9PV0///yzXnrpJS1YsEBLliwptqPEVu5Px44dM/+9z3smwZUy3gMXw6X7Lx6AYteoUSPdc889LrFdu3apXbt2io+PV+3atdWgQQNJ0ltvvaX09HStWbNGlSpVcvlMcnLyRetzYZQvX94lr7i4OFWrVk1vvfVWgUX3qVOn5HQ65ePjU6hlOBwOORyOYulvUVlV6BdWhw4d1KRJE/P9kCFDtGDBAt1222264447tHHjRvn7+0s6XaxcysVUYeUc2b+UDBo0SIsXL9bbb7+t/v37m/GHHnpI77zzjvr376/Bgwdr4sSJxbpcK7a/S23d5uXr66uWLVvq888/z1d0f/bZZ+rYsaO++uorD/Xu0tCtWzddc801kqQHH3xQPXr00IwZM7R8+XI1a9bMw727dOReT//973/VtWtXff311/r999/VokULt585duyYAgICCr0MT+1PV8p4D1wMnF4OXOUqVaqkqVOnKisrS2PGjDHj27ZtU4UKFfIV3JJUtmzZQs9/+/btio2NVYkSJRQREaEXXnhBhmFIkgzDUFRUlDp16pTvcydOnFBwcLAefPDBIucUHh6u2rVra8eOHZLOnF7/+uuva+zYsapatap8fX21YcMGSdKCBQvUqlUrlShRQqVKlVKnTp20ceNGl3kWdE33Tz/9ZH62ZMmS6tixo9avX5+vT5s2bdLdd9+t0NBQ+fv7q2bNmnr22WclnT4N8cknn5QkVa5c2TwdMWdZ7q6p3b59u+666y6FhIQoICBA1113nX744QeXNosWLZLNZtOXX36pl156SRUqVJCfn5/atm2rv//+u8jrNbebb75Zzz//vHbt2qVPP/3UjLu7xs9ms6l///6aOXOm6tSpI39/f7Vo0UJr166VJE2aNEnVqlWTn5+fbrrpJrfXzS9btkzt27dXcHCwAgIC1Lp1ay1ZssSlTc6y//77b/OIbXBwsPr27atjx465tJ03b55uuOEGlSpVSoGBgapZs6aGDh1qTi/omu7CbCtF6ceBAwe0adOmfPG89u7dq48++kg333yzS8Gd45FHHlGbNm304Ycfau/evWY8Z91Pnz5dNWvWlJ+fnxo3bqxffvnFpb9F2f5y9oXffvtNjz32mEJDQ1WqVCk9+OCDysrKUlpamuLi4lS6dGmVLl1aTz31lLnP5+5XzjWoeS9/yfvKrTDbgST99ttvatq0qfz8/FS1alVNmjTprOvXnf/85z/66aefXE6ZXrFihbZu3ar//Oc/+dqnpqZq8ODBio6OVmBgoIKCgtShQwf9+eef+dq+/fbbqlu3rgICAlS6dGk1adJEn3322Vn7s2vXLlWrVk316tXT/v373baZNWuWbDabFi9enG/apEmTZLPZtG7dOklSUlKS+vbtqwoVKsjX11flypVTp06dzvu+Fa1atZJ0+t+OHIVdJ0Udq95//31VrVpV/v7+atasmX799Ve3fUpOTla/fv0UFhYmPz8/NWjQQNOmTXNpk/vfh3feeUdVqlRRQECA2rVrpz179sgwDI0aNUoVKlSQv7+/OnXqpNTU1PNaR9LpsVOS+e/TTTfdpHr16mnlypW68cYbFRAQYI5Fhem/5P6a7n/++Uf33nuvwsLC5Ovrq7p162ry5Mn5PnvixAmNGDFCNWrUkJ+fn8qVK6cuXbpo27Zt2rlzp0JDQyVJI0eONPfJnGW5G+9PnTqlUaNGmf/ORkVFaejQocrMzHRpFxUVpdtuu02//fabmjVrJj8/P1WpUkUff/xx0VcqcBng5ykAatGihapWrap58+aZsUqVKmn+/PlasGCB+SWhqLKzs9W+fXtdd911GjNmjObMmaPhw4fr1KlTeuGFF2Sz2XTPPfdozJgxSk1NVUhIiPnZ//3vfzpy5Ei+I/OFcfLkSe3Zs0dlypRxiU+ZMkUnTpzQAw88IF9fX4WEhGj+/Pnq0KGDqlSpohEjRuj48eN6++231bJlS61atUpRUVEFLueTTz5RfHy8YmNj9eqrr+rYsWOaOHGibrjhBq1evdr87F9//aVWrVrJ29tbDzzwgKKiorRt2zb973//00svvaQuXbpoy5Yt+vzzz/XWW2+ZR0VyvuzktX//fl1//fU6duyYHnvsMZUpU0bTpk3THXfcoVmzZunOO+90af/KK6/Ibrdr8ODBOnz4sMaMGaNevXpp2bJlRV63ufXu3VtDhw7Vzz//rPvvv/+sbX/99Vd99913euSRRyRJo0eP1m233aannnpK7777rh5++GEdOnRIY8aM0b333qsFCxaYn12wYIE6dOigxo0ba/jw4bLb7ZoyZYpuvvlm/frrr/mOqt19992qXLmyRo8erVWrVunDDz9U2bJl9eqrr0qS1q9fr9tuu03169fXCy+8IF9fX/39999ui7fcirqtnKsfkjRhwgSNHDlSCxcuPOtNoH766SdlZ2crLi6uwDZxcXFauHCh5syZo/vuu8+ML168WDNmzNBjjz0mX19fvfvuu2rfvr2WL1+uevXqFXn7y/Hoo48qPDxcI0eO1O+//673339fpUqV0tKlS1WxYkW9/PLL+vHHH/Xaa6+pXr16BfY9NDRUn3zyiUvs5MmTevzxx13ORCnsdrB27Vq1a9dOoaGhGjFihE6dOqXhw4crLCzsrPnk1aVLF/33v//V119/rXvvvVfS6aPctWrVUqNGjfK13759u2bPnq277rpLlStX1v79+zVp0iS1bt1aGzZsUEREhCTpgw8+0GOPPaZu3bppwIABOnHihP766y8tW7bMbTEvnS5kb775ZoWEhGjevHnm3yivjh07KjAwUF9++aVat27tMm3GjBmqW7eu6tWrJ0nq2rWr1q9fr0cffVRRUVFKTk7WvHnztHv37rOOewXJKdZLly5d5HWSozBj1UcffaQHH3xQ119/vQYOHKjt27frjjvuUEhIiCIjI812x48f10033aS///5b/fv3V+XKlTVz5kz16dNHaWlpGjBggMuyp0+frqysLD366KNKTU3VmDFjdPfdd+vmm2/WokWL9PTTT+vvv//W22+/rcGDB7stYAsj50eJ3P8+HTx4UB06dFCPHj10zz33KCwsrMj9z23//v267rrrzB/dQkND9dNPP6lfv346cuSIBg4cKOn0v9G33XabEhIS1KNHDw0YMEBHjx7VvHnztG7dOsXExGjixIl66KGHdOedd6pLly6S5HJJUV733Xefpk2bpm7duumJJ57QsmXLNHr0aG3cuDHfvVb+/vtvdevWTf369VN8fLwmT56sPn36qHHjxqpbt+55rV/gkmUAuKxNmTLFkGSsWLGiwDY7duwwJBmvvfZagW06depkSDIOHz5sGIZhrFu3zvD39zckGQ0bNjQGDBhgzJ4928jIyChUv+Lj4w1JxqOPPmrGnE6n0bFjR8PHx8dISUkxDMMwNm/ebEgyJk6c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OHHC5TNVq1ZVyZIlz/tsgV69eqlChQou99Io7DoprCZNmig0NFTvvfeesrKyzPjUqVPzbbu33nqrkpKSNGPGDDN26tQpvf322woMDMx3d/dLzfn23+FwqGvXrvrqq6/c/tibe8zs2rWrDhw44PLvdI6cv1vOD2CF/bdJUr4fzd98801Jp++uD1ytONINXCEmT56sOXPm5IvnfqzIqlWr9Omnn8rpdCotLU0rVqzQV199JZvNpk8++cTllLNXX31VK1euVJcuXcz4qlWr9PHHHyskJMR85MjZ+Pn5ac6cOYqPj1fz5s31008/6YcfftDQoUPzPY6oY8eOKlOmjGbOnKkOHToU6VngF+K1115Thw4d1KJFC/Xr1898DFRwcPBZTyUNCgrSxIkT1bt3bzVq1Eg9evRQaGiodu/erR9++EEtW7Y0v8iMHz9eN9xwgxo1amReD79z50798MMPWrNmjSSZN7p69tln1aNHD3l7e+v22293e/T0mWee0eeff64OHTroscceU0hIiKZNm6YdO3boq6++KvC65PP1008/adOmTTp16pT279+vBQsWaN68eapUqZK+++47lyNzxc1ut+vDDz9Uhw4dVLduXfXt21fly5fXP//8o4ULFyooKEj/+9//ijTPF154Qb/88os6duyoSpUqKTk5We+++64qVKjgcnO6vM53Wzmbwj4yTJLeeustbdq0SQ8//LDmzJljHtGeO3euvv32W7Vu3VpvvPFGvs/Vq1dPsbGxLo8Mk+RyKnNRtr/itnbtWo0aNUo33nijkpOT8x1lveeee4q0HYwcOVJz5sxRq1at9PDDD5uFSt26dc1T8IvCbrfrueeeO2e72267TS+88IL69u2r66+/XmvXrtX06dPzXWvcrl07hYeHq2XLlgoLC9PGjRs1YcIEdezY0e2N8ux2uz799FN17txZd999t3788cdzPsbR29tbXbp00RdffKGMjAy9/vrrLtO3bNmitm3b6u6771adOnXk5eWlb775Rvv37z/vHzy9vb01YMAAPfnkk+b2Wdh1UpRlvPjii3rwwQd18803q3v37tqxY4emTJmSb54PPPCAJk2apD59+mjlypWKiorSrFmzzDOpznZTwkvBhfT/lVde0cKFC9W8eXPdf//9qlOnjlJTU7Vq1SrNnz/f/OExLi5OH3/8sQYNGqTly5erVatW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NfWClxEYGHjBd3R3OBwKDw+Xl5fnfw+KjIzUlClTXGLffPONAgMDPdQjAAAAAJcbiu6rxCOPPCIfHx/9/PPPat26tSpWrKgOHTpo/vz5+ueff/Tss8+abaOiojRq1Cj17NlTJUqUUPny5fXOO++4TJekO++8UzabzXyf9/TyPn36qHPnznr55ZcVFhamUqVK6YUXXtCpU6f05JNPKiQkRBUqVHApbPOeXt6nTx/ZbLZ8r0WLFkk6feR58ODBKl++vEqUKKHmzZub03JMnTpVFStWVEBAgO68804dPHiwUOssPj5eX3zxhY4fP27GJk+erPj4+Hxtn376adWoUUMBAQGqUqWKnn/+eZ08edKc/ueff6pNmzYqWbKkgoKC1LhxY/3xxx9ul5uSkqImTZrozjvvVGZmZqH6CgAAAODSRNF9FUhNTdXcuXP18MMP53vMWXh4uHr16qUZM2Yo99PjXnvtNTVo0ECrV6/WM888owEDBmjevHmSpBUrVkiSpkyZon379pnv3VmwYIH+/fdf/fLLL3rzzTc1fPhw3XbbbSpdurSWLVum//73v3rwwQe1d+9et58fN26c9u3bZ74GDBigsmXLqlatWpKk/v37KzExUV988YX++usv3XXXXWrfvr22bt0qSVq2bJn69eun/v37a82aNWrTpo1efPHFQq23xo0bKyoqSl999ZWk08+M/+WXX9S7d+98bUuWLKmpU6dqw4YNGjdunD744AO99dZb5vRevXqpQoUKWrFihVauXKlnnnlG3t7e+eazZ88etWrVSvXq1dOsWbOK5dnyAAAAADyHovsqsHXrVhmGodq1a7udXrt2bR06dEgpKSlmrGXLlnrmmWdUo0YNPfroo+rWrZtZRIaGhkqSSpUqpfDwcPO9OyEhIRo/frxq1qype++9VzVr1tSxY8c0dOhQVa9eXUOGDJGPj49+++03t58PDg5WeHi4wsPDtXTpUk2aNElff/21wsPDtXv3bk2ZMkUzZ85Uq1atVLVqVQ0ePFg33HCDefR83Lhxat++vZ566inVqFFDjz32mGJjYwu97u69915NnjxZ0ukj5rfeeqvbfJ977jldf/31ioqK0u23367Bgwfryy+/NKfv3r1bMTExqlWrlqpXr6677rpLDRo0cJnH5s2b1bJlS8XGxmrKlClyOByF7icAAACASxNF91Uk95Hsc2nRokW+9xs3bizyMuvWrSu7/cxmFhYWpujoaPO9w+FQmTJllJycfNb5rF69Wr1799aECRPUsmVLSdLatWuVnZ2tGjVqKDAw0HwtXrxY27ZtkyRt3LhRzZs3P2tuZ3PPPfcoMTFR27dv19SpU3Xvvfe6bTdjxgy1bNlS4eHhCgwM1HPPPafdu3eb0wcNGqT77rtPMTExeuWVV8z+5Th+/LhatWqlLl26aNy4cTw7GwAAALhCeP5uVbBctWrVZLPZtHHjRt155535pm/cuFGlS5c+6xHr85X3FGqbzeY25nQ6C5xHUlKS7rjjDt13333q16+fGU9PT5fD4dDKlSvzHRUurpudlSlTRrfddpv69eunEydOqEOHDjp69KhLm8TERPXq1UsjR45UbGysgoOD9cUXX+iNN94w24wYMUL/+c9/9MMPP+inn37S8OHD9cUXX5h/D19fX8XExOj777/Xk08+qfLlyxdL/wEAAHBxNV7V2NNduGKsbLTS010oFhzpvgqUKVNGt9xyi959912Xm4JJpwva6dOnq3v37i5HV3///XeXdr///rvL6ene3t7Kzs62tuOSTpw4oU6dOqlWrVp68803XaZde+21ys7OVnJysqpVq+byCg8Pl3T61Plly5bly6Uo7r33Xi1atEhxcXFuT/leunSpKlWqpGeffVZNmjRR9erVtWvXrnztatSooccff1w///yzunTp4nIDObvdrk8++USNGzdWmzZt9O+//xapjwAAAAAuTRTdV4kJEyYoMzNTsbGx+uWXX7Rnzx7NmTNHt9xyi8qXL6+XXnrJpf2SJUs0ZswYbdmyRe+8845mzpypAQPOPBw8KipKCQkJSkpK0qFDhyzr94MPPqg9e/Zo/PjxSklJUVJSkpKSkpSVlaUaNWqoV69eiouL09dff60dO3Zo+fLlGj16tH744QdJ0mOPPaY5c+bo9ddf19atWzVhwgTNmTOnSH1o3769UlJS9MILL7idXr16de3evVtffPGFtm3bpvHjx+ubb74xpx8/flz9+/fXokWLtGvXLi1ZskQrVqzId429w+HQ9OnT1aBBA918881KSkoq4toCAAAAcKmh6L5KVK9eXX/88YeqVKmiu+++W1WrVtUDDzygNm3aKDExUSEhIS7tn3jiCf3xxx+69tpr9eKLL+rNN990uQHZG2+8oXnz5ikyMlLX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/cEHH6h58+Yu03KKX39//wtaRlFcrL8PAAAAgHPjRmpXKbvdrqFDh+q5557T8ePHJUlLlixRp06ddM8996hBgwaqUqWKtmzZUqT51q5dW3v27NG+ffvM2O+//56vzZ9//qmMjAwztmTJEvM08uKW82NDxYoVC/WYsKL2LywsTBEREdq+fbuqVavm8qpcubKk02cHrFmzRqmpqW6X6ePjo+zs7GLtFwAAAADPo+i+it11111yOBx65513JJ2+PnvevHlaunSpNm7cqAcffFD79+8v0jxjYmJUo0YNxcfH688//9Svv/6qZ5991qVNr1695Ofnp/j4eK1bt04LFy7Uo48+qt69e7u9XvpiO5/+jRw5UqNHj9b48eO1ZcsWrV27VlOmTNGbb74pSerZs6fCw8PVuXNnLVmyRNu3b9dXX32lxMRESVJUVJR27NihNWvW6MCBA8rMzCyWfgEAAADwLIruq5iXl5f69++vMWPGKCMjQ88995waNWqk2NhY3XTTTWaRWBR2u13ffPONjh8/rmbNmum+++7TSy+95NImICBAc+fOVWpqqpo2bapu3bqpbdu2Ljd186Tz6d99992nDz/8UFOmTFF0dLRat26tqVOnmke6fXx89PPPP6ts2bK69dZbFR0drVdeecU8/bxr165q37692rRpo9DQ0HyPajvffgEAAADwLJthGIanO3GpOXLkiIKDg3X48GEFBQW5TDtx4oR27NihypUry8/Pz0M9hKcNGTJEv/76q3777TdPd+WCsU0DAIBK4zzdgyvHNa0ae7oLV4yVjVZ6ugtndba6MTeOdANFYBiGtm3bpoSEBNWtW9fT3QEAAABwiaPoBorg8OHDqlOnjnx8fMznhQMAAABAQXhkGFAEpUqVcnuTMwAAAABwhyPdAAAAAABYhKIbAAAAAACLUHSfJ6fT6ekuAMWCbRkAAACwDtd0F5GPj4/sdrv+/fdfhYaGysfHRzabzdPdAorMMAxlZWUpJSVFdrtdPj4+nu4SAAAAcMWh6C4iu92uypUra9++ffr333893R3gggUEBKhixYqy2znxBQAAAChuFN3nwcfHRxUrVtSpU6eUnZ3t6e4A583hcMjLy4uzNQAAAACLUHSfJ5vNJm9vb3l7e3u6KwAAAACASxTnkwIAAAAAYBGKbgAAAAAALELRDQAAAACARSi6AQAAAACw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vPGGOnbsqC+++EJ//PGH3n//fUmnz7MfOHCgXnzxRVWvXl2VK1fW888/r4iICLOwBwAAAADgYvB40d29e3elpKRo2LBhSkpKUsOGDTVnzhzzRmi7d+82L4aXpOuvv16fffaZnnvuOQ0dOlTVq1fX7NmzVa9ePbPNU089pYyMDD3wwANKS0vTDTfcoDlz5sjPz++i5wcAAAAAuHrZjHPdag24wmVmZmr06NEaMmRIvssMAACnMVYCwLkxVsIdim4AAAAAACxiP3cTAAAAAABwPii6AQAAAACwCEU3AAAAAAAWoejGFemXX37R7bffroiICNlsNs2ePducdvLkST399NOKjo5WiRIlFBERobi4OP37778u83D3uZ49e6p8+fJat27dRcoEAC6OV155xXzsZo5t27bpzjvvVGhoqIKCgnT33Xdr//79Lp9jrARwpTnb90hJ2r9/v/r06aOIiAgFBASoffv22rp1a775JCYm6uabb1aJEiUUFBSkG2+8UcePHzenM35ePSi6cUXKyMhQgwYN9M477+SbduzYMa1atUrPP/+8Vq1apa+//lqbN2/WHXfcUeD8jh07pjvuuEMrVqzQb7/95vKIOgC43K1YsUKTJk1S/fr1zVhGRobatWsnm82mBQsWaMmSJcrKytLtt98up9Ppdj6MlQCuBGf7HmkYhjp37qzt27fr22+/1erVq1WpUiXFxMQoIyPDbJeYmKj27durXbt2Wr58uVasWKH+/fu7PAo5N8bPK5vHn9MNWKFDhw7q0KGD22nBwcGaN2+eS2zChAlq1qyZdu/erYoVK7pMS0tLU8eOHZWenq7ffvtN4eHhlvUbAC629PR09erVSx988IFefPFFM75kyRLt3LlTq1evVlBQkCRp2rRpKl26tBYsWKCYmBiX+TBWArhSnO175NatW/X7779r3bp1qlu3riRp4sSJCg8P1+eff6777rtPkvT444/rscce0zPPPGN+tmbNmm7nyfh55eNINyDp8OHDstlsKlWqlEs8KSlJrVu3liQtXryYQRDAFeeRRx5Rx44d8xXRmZmZstlsLs+Z9fPzk91u12+//ebSlrESwNUiMzNT0unxMIfdbpevr685NiYnJ2vZsmUqW7asrr/+eoWFhal169b5xk6J8fNqQdGNq96JEyf09NNPq2fPnubRnBwDBgxQVlaW5s2bl68g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",
						"text/plain": [
							"<Figure size 1000x500 with 1 Axes>"
						]
					},
					"metadata": {},
					"output_type": "display_data"
				},
				{
					"data": {
						"image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAHqCAYAAAAZLi26AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAbk1JREFUeJzt3XmcjfX7x/H3OWfMZhZmYmYwZmxfSwZlixRlamxFX4TEWJIWIaWobG2WpBIhZamIqPCVCFFkabFkHcJkyTQYZsOMmXP//vCbwzEzZga3g3k9H4/zqHPd17nvz3Xu+9zjOvdyLIZhGAIAAAAAANec1dUDAAAAAADgVkXTDQAAAACASWi6AQAAAAAwCU03AAAAAAAmoekGAAAAAMAkNN0AAAAAAJiEphsAAAAAAJPQdAMAAAAAYBKabgAAAAAATELTDQCFULdu3RQeHu7qYdxQVq9eLYvFovnz57t6KNfMjBkzZLFY9Pvvv7t6KNdEbGysLBaLZsyYcd2XfTN9ZrK25dWrV7t6KFctPDxc3bp1c/UwAOCq0HQDgImymp6sh5ubm0qXLq1u3brpyJEjrh7eDePi92nt2rXZphuGodDQUFksFrVq1coFI7y8rGZw7Nixl80LDw931Gm1WlWsWDFFREToySef1MaNG3N8TUpKioYNG6bq1auraNGiCgwMVK1atdSvXz/9888/ZpRTYN26dXPazv38/FSzZk29++67SktLc/Xw8u2ff/7R8OHDtWXLFlcPxSFr28p6FClSRLfddpsaNmyoV155RQcPHnT1EAEAeXBz9QAAoDB4/fXXVa5cOZ09e1YbNmzQjBkztHbtWm3fvl2enp6uHt4Nw9PTU7Nnz1ajRo2c4j/99JMOHz4sDw8PF43s2qlVq5ZeeOEFSVJycrJ27dqlefPmaerUqXr++ec1btw4R+65c+d07733avfu3YqOjtZzzz2nlJQU7dixQ7Nnz9YjjzyiUqVKuaoUJx4eHvrkk08kSadOndLXX3+tF198Ub/99pvmzJlzTZYRFhamM2fOqEiRItdkfpf6559/NGLECIWHh6tWrVpO06ZOnSq73W7KcvOjU6dOatGihex2u06ePKnffvtN77//vj744AN9+umn6tixoyP33nvv1ZkzZ+Tu7u6y8V4rMTExslo5RgTg5kbTDQDXQfPmzVWnTh1J0hNPPKHbbrtNo0eP1qJFi/Too4+6eHQ3jhYtWmjevHkaP3683Nwu/ImaPXu2ateurePHj7twdNdG6dKl9fjjjzvFRo8erccee0zvvfeeKlWqpKefflqStGDBAm3evFmzZs3SY4895vSas2fPKj09/bqNOy9ubm5OdT3zzDOqX7++5s6dq3HjxuX45YBhGDp79qy8vLzytQyLxeKyL6nMavTz684778y23fz999968MEHFR0drapVq6pmzZqSJKvVest8mXcrfNEGAHx1CAAucM8990iS9u3b54ilp6dr6NChql27tvz9/VW0aFHdc889WrVqldNrLz6V+eOPP1aFChXk4eGhunXr6rfffsu2rAULFqh69ery9PRU9erV9e233+Y4ptTUVL3wwgsKDQ2Vh4eHKleurLFjx8owDKc8i8WiPn36aN68eapWrZq8vLzUoEEDbdu2TZI0ZcoUVaxYUZ6enmrSpIliY2Pz/b506tRJJ06c0PLly53el/nz52drOrOMHTtWDRs2VGBgoLy8vFS7du0cr8tevny5GjVqpGLFisnHx0eVK1fWK6+8ctnxpKWlqVWrVvL399e6devyXUdBeXl56fPPP1dAQIDeeustx3uetX3cfffd2V7j6ekpPz+/fM3/9OnT6t27twIDA+Xn56euXbvq5MmTjunR0dG67bbbdO7cuWyvffDBB1W5cuUC12S1WtWkSRNJcmwD4eHhatWqlZYtW6Y6derIy8tLU6ZMkSTt379f7du3V0BAgLy9vXXXXXfpu+++c5pnbtd07969W+3atVNAQIA8PT1Vp04dLVq0KNuYTp06peeff17h4eHy8PBQmTJl1LVrVx0/flyrV69W3bp1JUndu3d3nM6dtaycruku6Gcm67Po4eGh22+/XUuXLi3w+3qxsLAwzZgxQ+np6RozZowjntM13U2aNFH16tX1559/qnHjxvL29lbFihUdn5WffvpJ9evXl5eXlypXrqwVK1ZkW96RI0fUo0cPBQUFOWqYNm2aU07Wsr/66iu99dZbKlOmjDw9PdW0aVP99ddfTrl79+5V27ZtFRwcLE9PT5UpU0YdO3ZUYmKiIyena7rzs60UZBwAYDaabgBwgawmpHjx4o5YUlKSPvnkEzVp0kSjR4/W8OHDdezYMUVFReV4jens2bP1zjvvqHfv3nrzzTcVGxur//73v06N0w8//KC2bdvKYrFo5MiRatOmjbp3757txlqGYejhhx/We++9p2bNmmncuHGqXLmyBg4cqAEDBmRb9po1a/TCCy8oOjpaw4cP165du9SqVStNnDhR48eP1zPPPKOBAwdq/fr16tGjR77fl/DwcDVo0EBffvmlI/b9998rMTHR6fTZi33wwQe644479Prrr+vtt9+Wm5ub2rdv7/SP8B07dqhVq1ZKS0vT66+/rnfffVcPP/ywfvnll1zHcubMGT300ENat26dVqxYoYYNG+a7jivh4+OjRx55REeOHNHOnTslnW+qJOmzzz7L1sgVRJ8+fbRr1y4NHz5cXbt21axZs9SmTRvHPLt06aITJ05o2bJlTq+Li4vTjz/+mO0Ia35lfWkQGBjoiMXExKhTp0564IEH9MEHH6hWrVr6999/1bBhQy1btkzPPPOM3nrrLZ09e1YPP/xwrl8SZdmxY4fuuusu7dq1S4MGDdK7776rokWLqk2bNk6vTUlJ0T333KMPP/xQDz74oD744AM99dRT2r17tw4fPqyqVavq9ddflyQ9+eST+vzzz/X555/r3nvvzXG5Bf3MrF27Vs8884w6duyoMWPG6OzZs2rbtq1OnDhR4Pf1Yg0aNFCFChWcvqjKzcmTJ9WqVSvVr19fY8aMkYeHhzp27Ki5c+eqY8eOatGihUaNGqXU1FS1a9dOycnJjtf++++/uuuuu7RixQr16dNHH3zwgSpWrKiePXvq/fffz7asUaNG6dtvv9WLL76owYMHa8OGDercubNjenp6uqKiorRhwwY999xzmjhxop588knt379fp06dyrWGgm4reY0DAK4LAwBgmunTpxuSjBUrVhjHjh0zDh06ZMyfP98oUaKE4eHhYRw6dMiRm5GRYaSlpTm9/uTJk0ZQUJDRo0cPR+zAgQOGJCMwMNBISEhwxBcuXGhIMv73v/85YrVq1TJCQkKMU6dOOWI//PCDIckICwtzxBYsWGBIMt58802n5bdr186wWCzGX3/95YhJMjw8PIwDBw44YlOmTDEkGcHBwUZSUpIjPnjwYEOSU+7l3qfffvvNmDBhguHr62ucPn3aMAzDaN++vXHfffcZhmEYYWFhRsuWLZ1em5WXJT093ahevbpx//33O2LvvfeeIck4duxYrmNYtWqVIcmYN2+ekZycbDRu3Ni47bbbjM2bN1927IZxYZ288847l83LafwXyxrnwoULHbVVrlzZsb66detmfPrpp8a///6b55gM48L7Wrt2bSM9Pd0RHzNmjNNyMjMzjTJlyhgdOnRwev24ceMMi8Vi7N+//7LLiY6ONooWLWocO3bMOHbsmPHXX38Zb7/9tmGxWIwaNWo41S/JWLp0qdPr+/fvb0gy1qxZ44glJycb5cqVM8LDw43MzEzDMC68z9OnT3fkNW3a1IiIiDDOnj3riNntdqNhw4ZGpUqVHLGhQ4cakoxvvvkm2/jtdrthGIbx22+/ZZv/xTVezWfG3d3dKbZ161ZDkvHhhx9mW9bF8rNttW7d2pBkJCYmGoZxYVtetWqVI6dx48aGJGP27NmO2O7duw1JhtVqNTZs2OCIL1u2LNv70LNnTyMkJMQ4fvy407I7duxo+Pv7Oz6HWcuuWrWq0/7sgw8+MCQZ27ZtMwzDMDZv3uz4vF1OWFiYER0d7Xie320lv+MAgOuBI90AcB1ERkaqRIkSCg0NVbt27VS0aFEtWrRIZcqUceTYbDbHjY/sdrsSEhKUkZGhOnXqaNOmTdnm2aFDB6cj5VmnrO/fv1+SdPToUW3ZskXR0dHy9/d35D3wwAOqVq2a07yWLFkim82mvn37OsVfeOEFGYah77//3inetGlTp1Nt69evL0lq27atfH19s8WzxpQfjz76qM6cOaPFixcrOTlZixcvzvXUcklO1wOfPHlSiYmJuueee5zes2LFikmSFi5cmOfNsBITE/Xggw9q9+7dWr16dbYbapnJx8dHkhxHGL28vLRx40YNHDhQ0vm7vPfs2VMhISF67rnn8n1n8CeffNLpmuSnn35abm5uWrJkiaTzp4J37txZixYtcjq6OWvWLDVs2FDlypXLcxmpqakqUaKESpQooYoVK+qVV15RgwYNsh19LFeunKKiopxiS5YsUb169ZxuoOfj46Mnn3xSsbGxjiP/l0pISNCPP/6oRx99VMnJyTp+/LiOHz+uEydOKCoqSnv37nX8SsDXX3+tmjVr6pFHHsk2H4vFkmd9lyroZyYyMlIVKlRwPK9Ro4b8/PwK9NnIzaXbzeXyLj5jpHLlyipWrJiqVq3q+KxK2T+3hmHo66+/1kMPPSTDMBzv8/HjxxUVFaXExMRs+6ju3bs73cjt0v1T1j5p2bJlOn36dL5rLei2ktc4AOB6oOkGgOtg4sSJWr58uebPn68WLVro+PHjOd4gaObMmapRo4Y8PT0VGBioEiVK6LvvvnO6xjFL2bJlnZ5nNeBZ1+r+/fffkqRKlSple+2l1+j+/fffKlWqlFPDLElVq1Z1mlduy876B3RoaGiO8YuvH85LiRIlFBkZqdmzZ+ubb75RZmam2rVrl2v+4sWLddddd8nT01MBAQEqUaKEJk2a5PSedejQQXfffbeeeOIJBQUFqWPHjvrqq69ybMD79++v3377TStWrNDtt9+e73FfCykpKZLktB78/f01ZswYxcbGKjY2Vp9++qkqV66sCRMm6I033sjXfC/dBnx8fBQSEuJ0vX3Xrl115swZR5McExOjP/74Q126dMnXMjw9PbV8+XItX75cP//8sw4dOqRffvlF5cuXd8rLqYH/+++/c7xuPLftL8tff/0lwzA0ZMgQR8Of9Rg2bJgkKT4+XtL5U92rV6+er1ry42o/M9L5z2xBPhu5yWm7yUmZMmWyfcHg7++f5+f22LFjOnXqlD7++ONs73P37t0lXXifs+S1fypXrpwGDBigTz75RLfddpuioqI0ceLEHPd1FyvotpLXOADgeuDu5QBwHdSrV89x9/I2bdqoUaNGeuyxxxQTE+M4SvXFF1+oW7duatOmjQYOHKiSJUvKZrNp5MiRTjdcy2Kz2XJclnEV1/7mV27LvlZjeuyxx9SrVy/FxcWpefPmjiPVl1qzZo0efvhh3Xvvvfroo48UEhKiIkWKaPr06Zo9e7Yjz8vLSz///LNWrVql7777TkuXLtXcuXN1//3364cffnAad+vWrTVnzhyNGjVKn3322XX9uaLt27dLkipWrJjj9LCwMPXo0UOPPPKIypcvr1mzZunNN9+8JsuuVq2aateurS+++EJdu3bVF198IXd393zfXd9msykyMjLPvPzeqTw/sr40efHFF7MdPc+S23t5vZn5ed2+fbtKliyZ5431rvRzm/U+P/7444qOjs4xt0aNGgWapyS9++676tatmxYuXKgffvhBffv21ciRI7Vhwwans4Cuhiv3kwCQhaYbAK6zrEb6vvvu04QJEzRo0CBJ0vz581W+fHl98803Tkejso7YFVTWTbj27t2bbVpMTEy23BUrVig5OdnpaNnu3bud5nW9PPLII+rdu7c2bNiguXPn5pr39ddfy9PTU8uWLXM6c2D69OnZ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35133qmdO3eqYsWK2R7u7u6KiIiQ3W7XTz/9lOPr3d3dJemyN4W73u9bXuLj4zV79my1adNG1ku/sLpItWrVnG4oBwAAAFwPHOkupGw2m+NUYNulR+F1/rTxwMBAffzxxwoJCdHBgweznTqenJysLl26qG/fvmrevLnKlCmjunXr6qGHHlK7du3yPZbQ0FA98sgjGjp0qBYvXqxKlSrp4MGDmjNnjurWravvvvtO3377bYHq8/HxUc+ePTVw4EAFBgaqZMmSevXVV52askqVKql169bq1auXpkyZIl9fXw0aNEilS5dW69atC7Q8M1zJ+F5++WXddddd6tOnj5544gkVLVpUO3fu1PLlyzVhwgSFh4crOjpaPXr00Pjx41WzZk39/fffio+P16OPPqqwsDBZLBYtXrxYLVq0kJeXl9Np9Fc6roKIiYnJFrv99tslnT+NPC4uToZh6NSpU1q/fr3efvtt+fv7O26id+LECbVv3149evRQjRo15Ovrq99//11jxoy5IdYrAAAACheOdBdifn5+2a6TzmK1WjVnzhz98ccfql69up5//nm98847Tjn9+vVT0aJF9fbbb0uSIiIi9Pbbb6t37946cuRIgcby/PPP67vvvtOvv/6qhx9+WM8//7z69OmjWrVqad26dRoyZEiB63vnnXd0zz336KGHHlJkZKQaNWqk2rVrO+VMnz5dtWvXVqtWrdSgQQMZhqElS5ZkOzXaVQo6vho1auinn37Snj17dM899+iOO+7Q0KFDVapUKUfOpEmT1K5dO8fPu/Xq1ctxBLh06dIaMWKEBg0apKCgoFzPXDDzfevYsaPuuOMOp8e///4rSUpKSlJISIhKly6tBg0aaMqUKYqOjtbmzZsVEhIi6fwXLvXr19d7772ne++9V9WrV9eQIUPUq1cvTZgw4arHBwAAABSExTDrIsubWFJSkvz9/ZWYmJhjU3r27FkdOHBA5cqVk+elp40D19GyZcvUvHlznT171nFqOK4Mn2sAAAAURF59YxaOdAM3qX///VcLFy5UpUqVaLgBAACAGxTXdAM3qRYtWig5OVkfffSRq4cCAAAAIBc03cBN6o8//nD1EAAAAADkgdPLAQAAAAAwCU03AAAAAAAm4fRyAAAAALjYbIurRwBJeuzW+KEtjnQDAAAAAGASmm4AAAAAAExC0w0AAAAAgElounHdWCwWLViwwNXDMF1hqRMAAABA3riR2rV0vW+4UMAbC3Tr1k0zZ86UJLm5ualMmTJq3769Xn/9dXl6epoxwhtCVt29e/fW5MmTnaY9++yz+uijjxQdHa0ZM2a4ZoAAAAAAblkc6S5kmjVrpqNHj2r//v167733NGXKFA0bNszVwzJdaGio5syZozNnzjhiZ8+e1ezZs1W2bFkXjgwAAADArYymu5Dx8PBQcHCwQkND1aZNG0VGRmr58uWO6SdOnFCnTp1UunRpeXt7KyIiQl9++aXTPJo0aaK+ffvqpZdeUkBAgIKDgzV8+HCnnL179+ree++Vp6enqlWr5rSMLNu2bdP9998vLy8vBQYG6sknn1RKSopjerdu3dSmTRu9/fbbCgoKUrFixfT6668rIyNDAwcOVEBAgMqUKaPp06fnWfedd96p0NBQffPNN47YN998o7Jly+qOO+5wyl26dKkaNWqkYsWKKTAwUK1atdK+ffsc09PT09WnTx+FhITI09NTYWFhGjlyZK7LHjZsmEJCQvTnn3/mOU4AAAAAtxaa7kJs+/btWrdundzd3R2xs2fPqnbt2vruu++0fft2Pfnkk+rSpYt+/fVXp9fOnDlTRYsW1caNGzVmzBi9/vrrjsbabrfrv//9r9zd3bVx40ZNnjxZL7/8stPrU1NTFRUVpeLFi+u3337TvHnztGLFCvXp08cp78cff9Q///yjn3/+WePGjdOwYcPUqlUrFS9eXBs3btRTTz2l3r176/Dhw3nW26NHD6cGfdq0aerevXu2vNTUVA0YMEC///67Vq5cKavVqkceeUR2u12SNH78eC1atEhfffWVYmJiNGvWLIWHh2ebj2EYeu655/TZZ59pzZo1qlGjRp5jBAAAAHBr4ZruQmbx4sXy8fFRRkaG0tLSZLVaNWHCBMf00qVL68UXX3Q8f+6557Rs2TJ99dVXqlevniNeo0YNx2nplSpV0oQJE7Ry5Uo98MADWrFihXbv3q1ly5apVKlSkqS3335bzZs3d7x+9uzZOnv2rD777DMVLVpUkjRhwgQ99NBDGj16tIKCgiRJAQEBGj9+vKxWqypXrqwxY8bo9OnTeuWVVyRJgwcP1qhRo7R27Vp17NjxsrU//vjjGjx4sP7++29J0i+//KI5c+Zo9erVTnlt27Z1ej5t2jSVKFFCO3fuVPXq1XXw4EFVqlRJjRo1ksViUVhYWLZlZWRk6PHHH9fmzZu1du1alS5d+rJjAwAAAHBroukuZO677z5NmjRJqampeu+99+Tm5ubUZGZmZurtt9/WV199pSNHjig9PV1paWny9vZ2ms+lR21DQkIUHx8vSdq1a5dCQ0MdDbckNWjQwCl/165dqlmzpqPhlqS7775bdrtdMTExjqb79ttvl9V64YSMoKAgVa9e3fHcZrMpMDDQsezLKVGihFq2bKkZM2bIMAy1bNlSt912W7a8vXv3aujQodq4caOOHz/uOMJ98OBBVa9eXd26ddMDDzygypUrq1mzZmrVqpUefPBBp3k8//zz8vDw0IYNG3JcBgAAAIDCgdPLC5miRYuqYsWKqlmzpqZNm6aNGzfq008/dUx/55139MEHH+jll1/WqlWrtGXLFkVFRSk9Pd1pPkWKFHF6brFYHM3ptZTTcq5m2T169NCMGTM0c+ZM9ejRI8echx56SAkJCZo6dao2btyojRs3SpLjPbjzzjt14MABvfHGGzpz5oweffRRtWvXzmkeDzzwgI4cOaJly5bla1wAAAAAbk003YWY1WrVK6+8otdee81xV+9ffvlFrVu31uOPP66aNWuqfPny2rNnT4HmW7VqVR06dEhHjx51xDZs2JAtZ+vWrUpNTXXEfvnlF8dp5GZp1qyZ0tPTde7cOUVFRWWbfuLECcXExOi1115T06ZNVbVqVZ08eTJbnp+fnzp06KCpU6dq7ty5+vrrr5WQkOCY/vDDD2v27Nl64oknNGfOHNPqAQAAAHBjo+ku5Nq3by+bzaaJEydKOn999vLly7Vu3Trt2rVLvXv31r///lugeUZGRuo///mPoqOjtXXrVq1Zs0avvvqqU07nzp3l6emp6Ohobd++XatWrdJzzz2nLl26OE4tN4PNZtOuXbu0c+dO2Wy2bNOLFy+uwMBAffzxx/rrr7/0448/asCAAU4548aN05dffqndu3drz549mjdvnoKDg1WsWDGnvEceeUSff/65unfvrvnz55tWEwAAAIAbF013Iefm5qY+ffpozJgxSk1N1WuvvaY777xTUVFRatKkiYKDg9WmTZsCzdNqterbb7/VmTNnVK9ePT3xxBN66623nHK8vb21bNkyJSQkqG7dumrXrp2aNm3qdFM3s/j5+cnPzy/Xsc+ZM0d//PGHqlevrueff17vvPOOU46vr6/GjBmjOnXqqG7duoqNjdWSJUucrj3P0q5dO82cOVNdunRx+rkyAAAAAIWDxTAMw9WDuNEkJSXJ399fiYmJOTZnZ8+e1YEDB1SuXDl5enq6YIQArjU+1wAAwGG2xdUjgCQ9dmO3qnn1jVk40g0AAAAAgElougEAAAAAMAlNNwAAAAAAJqHpBgAAAADAJDTdAAAAAACYhKb7KnDjd+DWwecZAAAAZqDpvgJFihSRJJ0+fdrFIwFwrWR9nrM+3wAAAMC14ObqAdyMbDabihUrpvj4eEmSt7e3LBZ+yw+4GRmGodOnTys+Pl7FihWTzWZz9ZAAAABwC6HpvkLBwcGS5Gi8AdzcihUr5vhcAwAAANcKTfcVslgsCgkJUcmSJXXu3DlXDwfAVShSpAhHuAEAAGAKmu6rZLPZ+Mc6AAAAACBH3EgNAAAAAACTcKQbAAAAyM1sbpbrco/xs564uXGkGwAAAAAAk9wQTffEiRMVHh4uT09P1a9fX7/++muuuVOnTtU999yj4sWLq3jx4oqMjMyWbxiGhg4dqpCQEHl5eSkyMlJ79+41uwwAAAAAAJy4vOmeO3euBgwYoGHDhmnTpk2qWbOmoqKicv0prtWrV6tTp05atWqV1q9fr9DQUD344IM6cuSII2fMmDEaP368Jk+erI0bN6po0aKKiorS2bNnr1dZAAAAAADIYhiGSy+SqF+/vurWrasJEyZIkux2u0JDQ/Xcc89p0KBBeb4+MzNTxYsX14QJE9S1a1cZhqFSpUrphRde0IsvvihJSkxMVFBQkGbMmKGOHTvmOc+kpCT5+/srMTFRfn5+V1cgAAAAbl5c0+16rrimm/V+Y7jBr+fPb9/o0iPd6enp+uOPPxQZGemIWa1WRUZGav369fmax+nTp3Xu3DkFBARIkg4cOKC4uDinefr7+6t+/fr5nicAAAAAANeCS+9efvz4cWVmZiooKMgpHhQUpN27d+drHi+//LJKlSrlaLLj4uIc87h0nlnTLpWWlqa0tDTH86SkJEnnj6JnZmZKkiwWi6xWq+x2uy4+OSArnpWXV9xqtcpiseQYl84f6c9P3GazyTCMHOOXjjG3ODVREzVREzVREzVREzXlVVMRWZQpq+zKlJukC0dAc4tblSGLDGWqiPPYlSHJkD1b/Jwki+yX/NPcpnMyssUN2ZQhu6wyZMszbpFdVmXKLpuMi4633VQ1uWrbYz25vqbMzBt6H3HpmHJzU/9k2KhRozRnzhytXr1anp6eVzyfkSNHasSIEdniO3bskI+PjyQpICBAZcuW1eHDh5WQkODICQ4OVnBwsGJjY5WcnOyIh4aGKjAwUHv37nW6lrx8+fLy8/PTzp07nVZS5cqV5e7urm3btjmNISIiQunp6YqJiXHEbDabIiIilJycrP379zvinp6eqlKlik6ePKlDhw454r6+vqpQoYLi4+OdvnigJmqiJmqiJmqiJmqipjxqcn9CwZm/KzjzN8W6NVOyNfRCTRmrFWjfpb1F2umspfiFms4tlp9xSDvduypT7hdqOjdH7kaKtrk/4VxT+idKt/gopsiFyyBtSldE+qdKtpTR/iKtLtRknFSVc3N00lpZh9yaXKjJfkgVMhYr3lZbcbY6F2qy71LZjNU67HaPEqxVHfGbqiZXbHsqwnq6EWratu2G3kekpKQoP1x6TXd6erq8vb01f/58tWnTxhGPjo7WqVOntHDhwlxfO3bsWL355ptasWKF6tS5sHL379+vChUqaPPmzapVq5Yj3rhxY9WqVUsffPBBtnnldKQ7NDRUCQkJjnPzC8+3udRETdRETdRETdRETdTkiM/14mijq2vqmHn9t70vraynG6GmDmdu6H1EUlKSAgIC8rym26VHut3d3VW7dm2tXLnS0XTb7XatXLlSffr0yfV1Y8aM0VtvvaVly5Y5NdySVK5cOQUHB2vlypWOpjspKUkbN27U008/neP8PDw85OHhkS1us9lks9mcYlkrMafc6x23WCw5xnMbY0Hj1ERNucWpiZqu1RgLGqcmarpWYyxonJoKc03nLixTGTmPJdf4uQLEjRzjllziVtkl2QsQz5SU/VTYm6ImV217rCfX13TRurkR9xG5LftSLj+9fMCAAYqOjladOnVUr149vf/++0pNTVX37t0lSV27dlXp0qU1cuRISdLo0aM1dOhQzZ49W+Hh4Y7D/T4+PvLx8ZHFYlH//v315ptvqlKlSipXrpyGDBmiUqVKOR1NBwAAAADAbC5vujt06KBjx45p6NChiouLU61atbR06VLHjdAOHjzo9A3DpEmTlJ6ernbt2jnNZ9iwYRo+fLgk6aWXXlJqaqqefPJJnTp1So0aNdLSpUuv6rpvAAAAAAAKyuW/030j4ne6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Ro4cKUnq16+fGjdurHfffVctW7bUnDlz9Pvvv+vjjz+WdP48+/79++vNN99UpUqVVK5cOQ0ZMkSlSpVyNPYAAAAAAFwPLm+6O3TooGPHjmno0KGKi4tTrVq1tHTpUseN0A4ePOi4GF6SGjZsqNmzZ+u1117TK6+8okqVKmnBggWqXr26I+ell15SamqqnnzySZ06dUqNGjXS0qVL5enped3rAwAAAAAUXi7/nW4UXmlpaRo5cqQGDx6c7fR+AACuFf7eoDBj+y+cWO83FppuAAAAAABMYs07BQAAAAAAXAmabgAAAAAATELTDQAAAACASWi6YarMzEwNGTJE5cqVk5eXlypUqKA33nhDF99KoEmTJk6/uy5JH3zwgTw8PDRnzpzrPGIAwM0gPDxcFosl2+PZZ5915Kxfv17333+/ihYtKj8/P9177706c+aMY7rFYtGCBQscz8+dO6dOnTqpdOnS2r59+/UsB8jVyJEjVbduXfn6+qpkyZJq06aNYmJinHI+/vhjNWnSRH5+frJYLDp16pTT9NjYWPXs2dPp32PDhg1Tenq6I2f16tXZXvvPP/8oIiJC9957rxITE80sE3kYNWqU46eRs+S13rN89913ql+/vry8vFS8eHGnn1GOjY2VxWLRli1bHLHk5GTdd999qlatmg4fPmxOQYWMy38yDLe20aNHa9KkSZo5c6Zuv/12/f777+revbv8/f3Vt2/fHF8zbNgwjR07VgsXLlSzZs2u84gBADeD3377TZmZmY7n27dv1wMPPKD27dtLOt9wN2vWTIMHD9aHH34oNzc3bd261elnSC92+vRptW3bVnv37tXatWtVrly561IHkJeffvpJzz77rOrWrauMjAy98sorevDBB7Vz504VLVpU0vntt1mzZo5t/lK7d++W3W7XlClTVLFiRW3fvl29evVSamqqxo4dm+Ny9+3bpwceeEDVqlXTvHnz5OXlZWqdyN1vv/2mKVOmqEaNGk7xvNa7JH399dfq1auX3n77bd1///3KyMi47JeKx44dU/PmzWW1WrVmzRoFBgZe01oKK5pumGrdunVq3bq1WrZsKen8kYkvv/xSv/76a7ZcwzDUt29fffHFF1q+fLkaNmx4vYcLALhJlChRwun5qFGjVKFCBTVu3FiS9Pzzz6tv374aNGiQI6dy5co5zuvUqVNq2bKlUlJStHbtWgUHB5s3cKCAli5d6vR8xowZKlmypP744w/de++9kuQ4+rl69eoc55HVmGUpX768YmJiNGnSpByb7j///FNRUVG6//77NXPmTLm50TK4SkpKijp37qypU6fqzTffdJqW13rPyMhQv3799M4776hnz56OeLVq1XLMP3TokB544AGVLl1aCxculI+PzzWpAZxeDpM1bNhQK1eu1J49eyRJW7du1dq1a9W8eXOnvIyMDD3++OOaP3++fvrpJxpuAEC+paen64svvlCPHj1ksVgUHx+vjRs3qmTJkmrYsKGCgoLUuHFjrV27Nttr4+LiHI36Tz/9RMONG17Wad4BAQFXPZ+c5rFu3To1btxYbdu21RdffEHD7WLPPvusWrZsqcjIyAK/dtOmTTpy5IisVqvuuOMOhYSEqHnz5jke6Y6JidHdd9+tatWqacmSJTTc1xifIphq0KBBSkpKUpUqVWSz2ZSZmam33npLnTt3dsqbOnWqpPNNeZUqVVwxVADATWrBggU6deqUunXrJknav3+/JGn48OEaO3asatWqpc8++0xNmzbV9u3bValSJcdr+/Xrp/Lly2v58uXy9vZ2xfCBfLPb7erfv7/uvvtuVa9e/Yrn89dff+nDDz/M8Sj3I488og4dOmjChAlXM1RcA3PmzNGmTZv022+/XdHrL94Xjhs3TuHh4Xr33XfVpEkT7dmzx+lLl65du+ruu+/WvHnzZLPZrsn4cQFHumGqr776SrNmzdLs2bO1adMmzZw5U2PHjtXMmTOd8ho1aiQfHx8NGTJEGRkZLhotAOBm9Omnn6p58+YqVaqUpPONiST17t1b3bt31x133KH33ntPlStX1rRp05xe26pVK+3Zs0dTpky57uMGCurZZ5/V9u3br+pGs0eOHFGzZs3Uvn179erVK9v01q1b69tvv9WaNWuuZqi4SocOHVK/fv00a9YseXp6XtE8svaFr776qtq2bavatWtr+vTpslgsmjdvnlPuww8/rDVr1uibb7656rEjO5pumGrgwIEaNGiQOnbsqIiICHXp0kXPP/+8Ro4c6ZQXERGhlStXatWqVerQoQONNwAgX/7++2+tWLFCTzzxhCMWEhIiKft1i1WrVtXBgwedYl26dNG0adP04osvaty4ceYPGLhCffr00eLFi7Vq1SqVKVPmiubxzz//6L777lPDhg31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pK+++koxMTGaNWuWwsPDcxzf9X7fAACFgAEAAAzDMIzo6GijdevWhmEYht1uN5YvX254eHgYL774omN6UFCQkZaW5njNxx9/bBQvXtxISUlxxL777jvDarUacXFxhmEYxrBhw4yaNWs6pleoUMGYPXu207LfeOMNo0GDBoZhGMaUKVMMX19f48SJEzmO89L5ZZFkfPvtt/keV3R0tBEWFmZkZGQ4ctq3b2906NAh1/do+vTphr+/f47TJk2aZEgy/v33X8MwDKNx48ZGv379HNPDwsKMxx9/3PH86NGjhiRjyJAhjtj69esNScbRo0cNwzCMnj17Gk8++aTTctasWWNYrVbjzJkzOc7XbrcbJUuWNCZNmmQYhmE899xzxv3332/Y7fYcx3093jcAQOHFkW4AAC6yePFi+fj4yNPTU82bN1eHDh00fPhwx/SIiAin67h37dqlmjVrqmjRoo7Y3XffLbvd7jjSerHU1FTt27dPPXv2dFzr7ePjozfffFP79u2TJG3ZskV33HHHVV0Tnd9x3X777bLZbI7nISEhio+Pv6JlGv9/dNpiseSaU6NGDcf/BwUFSTr/nl4ayxrD1q1bNWPGDKf3KioqSna7XQcOHMhxvlmnv2fNo1u3btqyZYsqV66svn376ocffsh1fK543wAAtzZupAYAwEXuu+8+TZo0Se7u7ipVqlS2u5Zf3Ixdiaxrg6dOnar69es7Tctq4ry8vK5qGQVRpEgRp+cWi0V2u/2K5rVr1y75+fld9i7tFy8vqznPKZY1hpSUFPXu3Vt9+/bNNq+yZcvmON+s+WTN484779SBAwf0/fffa8WKFXr00UcVGRmp+fPnF7TEfC0PAICL0XQDAHCRokWLqmLFivnOr1q1qmbMmKHU1FRHQ/7LL7/IarU6brR2saCgIJUqVUr79+9X586dc5xnjRo19MknnyghISHHo93u7u6XvW76SsZ1teLj4zV79my1adNGVuu1O5Huzjvv1M6dOwu0TnLi5+enDh06qEOHDmrXrp2aNWuW4/t7vd83AMCtj9PLAQC4Cp07d5anp6eio6O1fft2rVq1Ss8995y6dOniOFX6UiNGjNDIkSM1fvx47dmzR9u2bdP06dM1btw4SVKnTp0UHBysNm3a6JdfftH+/fv19ddfa/369ZLO3637wIED2rJli44fP660tLRrMq78MgxDcXFxOnr0qHbt2qVp06apYcOG8vf316hRo65q3pd6+eWXtW7dOvXp00dbtmzR3r17tXDhwsveqO5S48aN05dffqndu3drz549mjdvnoKDg1WsWLFsuWa+bwCAwommGwCAq+Dt7a1ly5YpISFBdevWVbt27dS0aVNNmDAh19c88cQT+uSTTzR9+nRFRESocePGmjFjhsqVKyfp/JHsH374QSVLllSLFi0UERGhUaNGOU4/b9u2rZo1a6b77rtPJUqU0JdffnlNxpVfSUlJCgkJUenSpdWgQQNNmTJF0dHR2rx5s0JCQq56/herUaOGfvrpJ+3Zs0f33HOP7rjjDg0dOtTxW+D54evrqzFjxqhOnTqqW7euYmNjtWTJkhyPyJv5vgEACieLkXXXEwAAYIrBgwdrzZo1Wrt2rauHAgAArjOOdAMAYBLDMLRv3z6tXLlSt99+u6uHAwAAXICmGwAAkyQmJqpatWpyd3fXK6+84urhAAAAF+D0cgAAAAAATMKRbgAAAAAATELTDQAAAACASWi6AQAAAAAwCU03AAAAAAAmoekGAAAAAMAkNN0AAAAAAJiEphsAAAAAAJPQdAMAAAAAYBKabgAAAAAATPJ/ywfBzSId7WQAAAAASUVORK5CYII=",
						"text/plain": [
							"<Figure size 1000x500 with 1 Axes>"
						]
					},
					"metadata": {},
					"output_type": "display_data"
				}
			],
			"source": [
				"import os\n",
				"import numpy as np\n",
				"import matplotlib.pyplot as plt\n",
				"from collections import defaultdict\n",
				"import math\n",
				"import torch\n",
				"\n",
				"# === Configs ===\n",
				"results_dir = \"./results\"\n",
				"train_setting = \"wd=0.0_lr=5e-5\"\n",
				"total_params = 85017600\n",
				"num_layers = 48\n",
				"methods = [\"Localize-16*16\", \"Localize-32*32\", \"Localize-64*64\",\n",
				"           \"Random Drop-0.93\", \"Random Drop-0.95\", \"Random Drop-0.97\", \"Random Drop-0.99\",\n",
				"           \"LoGra-16*16\", \"LoGra-32*32\", \"LoGra-64*64\"]\n",
				"result_file = [\"GC/IF-RAW/Linear/Localize-16*16_thrd-0.0_rdp-0.0.pt\", \"GC/IF-RAW/Linear/Localize-32*32_thrd-0.0_rdp-0.0.pt\", \"GC/IF-RAW/Linear/Localize-64*64_thrd-0.0_rdp-0.0.pt\",\n",
				"               \"GC/IF-RAW/Linear/Identity-64*64_thrd-0.0_rdp-0.93.pt\", \"GC/IF-RAW/Linear/Identity-64*64_thrd-0.0_rdp-0.95.pt\", \"GC/IF-RAW/Linear/Identity-64*64_thrd-0.0_rdp-0.97.pt\", \"GC/IF-RAW/Linear/Identity-64*64_thrd-0.0_rdp-0.99.pt\",\n",
				"               \"LoGra/IF-RAW/Linear/Random-16*16_thrd-0.0_rdp-0.0.pt\", \"LoGra/IF-RAW/Linear/Random-32*32_thrd-0.0_rdp-0.0.pt\", \"LoGra/IF-RAW/Linear/Random-64*64_thrd-0.0_rdp-0.0.pt\"]\n",
				"# Updated legend names\n",
				"group_display_names = {\n",
				"    \"Localize\": \"Optimized Mask\",\n",
				"    \"Random Drop\": \"Random Mask\",\n",
				"    \"LoGra\": \"Random Projection\"\n",
				"}\n",
				"group_colors = {\n",
				"    \"Localize\": \"dodgerblue\",\n",
				"    \"Random Drop\": \"orange\",\n",
				"    \"LoGra\": \"limegreen\"\n",
				"}\n",
				"\n",
				"# === Step 1: Collect LDS results ===\n",
				"data_by_proj_dim = defaultdict(dict)\n",
				"data_by_group = defaultdict(dict)\n",
				"max_logra_lds = 0\n",
				"\n",
				"for idx, method in enumerate(methods):\n",
				"    filename = os.path.join(results_dir, train_setting, result_file[idx])\n",
				"    # Determine group and projection ratio\n",
				"    if \"Localize\" in method:\n",
				"        group = \"Localize\"\n",
				"        dim = int(method.split(\"-\")[1].split(\"*\")[0])\n",
				"        proj_dim = num_layers * dim * dim\n",
				"        ratio = proj_dim / total_params\n",
				"    elif \"LoGra\" in method:\n",
				"        group = \"LoGra\"\n",
				"        dim = int(method.split(\"-\")[1].split(\"*\")[0])\n",
				"        proj_dim = num_layers * dim * dim\n",
				"        ratio = proj_dim / total_params\n",
				"    elif \"Random Drop\" in method:\n",
				"        group = \"Random Drop\"\n",
				"        drop_rate = float(method.split(\"-\")[1])\n",
				"        # Note: adjusting ratio calculation as per your instruction\n",
				"        ratio = (1 - drop_rate) ** 2\n",
				"        proj_dim = int(ratio * total_params)\n",
				"    else:\n",
				"        continue\n",
				"\n",
				"    if os.path.exists(filename):\n",
				"        data = torch.load(filename, weights_only=False)\n",
				"        lds = data.get(\"lds\", None)\n",
				"        if lds is not None:\n",
				"            data_by_proj_dim[proj_dim][group] = lds\n",
				"            data_by_group[group][proj_dim] = lds\n",
				"\n",
				"            # Track maximum LoGra LDS\n",
				"            if group == \"LoGra\" and lds > max_logra_lds:\n",
				"                max_logra_lds = lds\n",
				"        else:\n",
				"            print(f\"Warning: 'lds' not found in {filename}\")\n",
				"    else:\n",
				"        print(f\"Warning: File not found: {filename}\")\n",
				"\n",
				"# Function to prepare x positions based on log scale\n",
				"def prepare_x_positions(dimensions):\n",
				"    log_dims = [math.log10(d) for d in dimensions]\n",
				"    min_log = min(log_dims)\n",
				"    max_log = max(log_dims)\n",
				"    # Normalize to get evenly spaced positions based on log scale\n",
				"    normalized_positions = [(ld - min_log) / (max_log - min_log) * (len(dimensions) - 1) for ld in log_dims]\n",
				"    return np.array(normalized_positions)\n",
				"\n",
				"# Function to format dimension labels\n",
				"def format_dimension_labels(dimensions):\n",
				"    dim_labels = []\n",
				"    for d in dimensions:\n",
				"        if d < 1000:\n",
				"            dim_labels.append(f\"{int(d)}\")\n",
				"        elif d < 1_000_000:\n",
				"            dim_labels.append(f\"{int(d/1000)}K\")\n",
				"        else:\n",
				"            dim_labels.append(f\"{d/1_000_000:.2f}M\")\n",
				"    return dim_labels\n",
				"\n",
				"# === Plot 1: Localize and LoGra together ===\n",
				"plt.figure(figsize=(10, 5))\n",
				"# Get the dimensions for Localize and LoGra groups only\n",
				"plot1_dims = sorted(set([d for d in data_by_proj_dim.keys()\n",
				"                     if \"Localize\" in data_by_proj_dim[d] or \"LoGra\" in data_by_proj_dim[d]]))\n",
				"x1 = prepare_x_positions(plot1_dims)\n",
				"bar_width = 0.25  # Wider since we have fewer groups per dimension\n",
				"\n",
				"legend_shown = set()\n",
				"for i, dim in enumerate(plot1_dims):\n",
				"    groups = [g for g in data_by_proj_dim[dim].keys() if g in [\"Localize\", \"LoGra\"]]\n",
				"    num_groups = len(groups)\n",
				"    start = x1[i] - (num_groups - 1) * bar_width / 2\n",
				"    for j, group in enumerate(groups):\n",
				"        lds = data_by_proj_dim[dim][group]\n",
				"        xpos = start + j * bar_width\n",
				"        # Use the display name for the legend instead of the internal group name\n",
				"        label = group_display_names[group] if group not in legend_shown else None\n",
				"        plt.bar(xpos, lds, width=bar_width, color=group_colors[group], label=label)\n",
				"        legend_shown.add(group)\n",
				"\n",
				"plt.xticks(x1, format_dimension_labels(plot1_dims))\n",
				"plt.xlabel(\"Projection Dimension\")\n",
				"plt.ylabel(\"LDS\")\n",
				"plt.title(\"LDS by Projection Dimension: Optimized Mask vs Random Projection\")\n",
				"plt.legend()\n",
				"plt.grid(axis='y', linestyle='--', alpha=0.6)\n",
				"plt.tight_layout()\n",
				"plt.show()\n",
				"\n",
				"# === Plot 2: Random Drop with LoGra max line ===\n",
				"plt.figure(figsize=(10, 5))\n",
				"# Get the projection dimensions for Random Drop only\n",
				"plot2_dims = sorted([d for d in data_by_proj_dim.keys() if \"Random Drop\" in data_by_proj_dim[d]])\n",
				"x2 = prepare_x_positions(plot2_dims)\n",
				"bar_width = 0.4  # Wider since we only have one group per dimension\n",
				"\n",
				"# Plot Random Drop bars\n",
				"for i, dim in enumerate(plot2_dims):\n",
				"    lds = data_by_proj_dim[dim][\"Random Drop\"]\n",
				"    plt.bar(x2[i], lds, width=bar_width, color=group_colors[\"Random Drop\"],\n",
				"            label=group_display_names[\"Random Drop\"] if i == 0 else None)\n",
				"\n",
				"# Add horizontal dashed line for max LoGra LDS\n",
				"plt.axhline(y=max_logra_lds, linestyle='--', color='red',\n",
				"            label=f\"Max {group_display_names['LoGra']} LDS\")\n",
				"\n",
				"plt.xticks(x2, format_dimension_labels(plot2_dims))\n",
				"plt.xlabel(\"Projection Dimension\")\n",
				"plt.ylabel(\"LDS\")\n",
				"plt.title(\"Random Mask LDS by Projection Dimension\")\n",
				"plt.legend(loc='upper left', bbox_to_anchor=(0.001, 0.95))\n",
				"plt.grid(axis='y', linestyle='--', alpha=0.6)\n",
				"plt.tight_layout()\n",
				"plt.show()"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": []
		}
	],
	"metadata": {
		"kernelspec": {
			"display_name": "IF",
			"language": "python",
			"name": "python3"
		},
		"language_info": {
			"codemirror_mode": {
				"name": "ipython",
				"version": 3
			},
			"file_extension": ".py",
			"mimetype": "text/x-python",
			"name": "python",
			"nbconvert_exporter": "python",
			"pygments_lexer": "ipython3",
			"version": "3.10.16"
		}
	},
	"nbformat": 4,
	"nbformat_minor": 2
}
