{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "appointed-appraisal",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy\n",
    "from scipy.integrate import solve_ivp\n",
    "\n",
    "\n",
    "kwargs = {'linewidth' : 7}\n",
    "\n",
    "# Define the function f(x)\n",
    "def f(x):\n",
    "    return  (x**2 -  3)**2 + 2*x\n",
    "\n",
    "def differential_eq_1(t, y):\n",
    "    x, dxdt = y\n",
    "    ddxdt = - 4*x*(x**2 -3) - 2\n",
    "    return [dxdt, ddxdt]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "emotional-bahrain",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "x_init = 2.2\n",
    "max_iterations = 10\n",
    "mean_duration  = 2.0\n",
    "\n",
    "#def HD(max_duration, mean_duration, x_init):\n",
    "\n",
    "t_HD   = np.empty(shape=[0,])\n",
    "x_HD   = np.empty(shape=[0,])\n",
    "\n",
    "x      = x_init\n",
    "t      = 0\n",
    "\n",
    "for k in range( max_iterations ):\n",
    "\n",
    "    x0    = x\n",
    "    dxdt0 = 0\n",
    "    initial_conditions = [x0, dxdt0]\n",
    "\n",
    "    duration = np.random.exponential( mean_duration, 1)      # Duration of the flow\n",
    "    duration = np.squeeze(duration)\n",
    "    t_span = (0, duration)    \n",
    "    t_eval  = np.linspace(0, duration, 100)            # Time points where we want the solution\n",
    "    #    print(t_eval.shape)\n",
    "    \n",
    "    sol = solve_ivp(differential_eq_1, t_span, initial_conditions, t_eval=t_eval)\n",
    "\n",
    "    x_HD_tmp = sol.y[0]\n",
    "    t_HD_tmp = sol.t \n",
    "    t_HD_tmp += t\n",
    "    \n",
    "    t_HD = np.append( t_HD, t_HD_tmp )\n",
    "    x_HD = np.append( x_HD, x_HD_tmp )\n",
    "\n",
    "    x = x_HD[-1]\n",
    "    t = t_HD[-1]\n",
    "\n",
    "#        return x_HD, t_HD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "bizarre-malaysia",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def Chebyroot(k, alpha=1.0, beta=10):\n",
    "   assert beta > alpha\n",
    "   a = np.arange(1,k+1)\n",
    "   return (alpha+beta)/2.0  - (beta-alpha)/2.0*np.cos( (a -0.5)*np.pi / k  )  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "beautiful-array",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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3bu+ycmd1K9fR/8OCH5TWFio5cuXq1evXiUnpcI+mF/7Ym7tzd/ze/z4cWVlZalhw4Zen/tysltvlerXN/TAA45SpcyTk6Xp0w2lpdWX5OUurRqIiYlRREREqe9GkZGRqlevXoXfl+rXr6+4uDjdcccdmjFjhoYNG6annnpKiYmJ2rx5s1q1aqUuXbrozDPP1M6dO/XTTz8pOTlZjRo1KjknybONESNG6Omnn9b999+v8ePHa9++fXr00Uf1+9//vuR8qqioKEVGRpYaS7169Uq1RURElGy7f//+6tKli4YOHaopU6bozDPP1O7du/Wvf/1LAwYMUPv27fXHP/5RN9xwg9q1a6ddu3bpq6++UlpamuLi4vTAAw+oT58+OuOMM/Trr79q/fr1at++faXfHSt7r2JiYuRwOEraPZ+Jo0ePyjAM/fbbb/rss8/05z//WU2aNNHUqVMrfY64uDhdcMEF2rJli7p27VrSfvDgQe3cubOkBPquXbvUoEEDtWzZUi1btlRcXJyGDx+ucePGKTk5WfHx8frjH/+oDh066Lrrriu3R6aq1/TAAw/ozTff1D333KOHHnpITZs21X//+18tWLBAL7/8sjZu3KhPP/1UvXr1UvPmzfX5559r//79Ov/88xUXF6fx48dr9OjRatasmfr06aP8/Hxt3LhRv/32mx544AHFxsaqfv36Wrt2rc4880zFxMTo4MGDeuWVV3TttdcqLi5O2dnZ+vHHHzVs2LCSsW3evFmnnnqqOnas+Hvz8ePHVb9+fV1xxRXlfi8rC5AVvide9wyAUaNG6f3339fq1auVnJzs1WMWLFigESNGaOHChZWWbZTM2vAVrTMQFRUVlP8Ye/SQTjlF+vXX6vtmZTkVFcVJUKEuWJ81BAbza1/Mrb35a37dbrccDociIiIUEVG7oseDBknXXy+tWSPl5EiJiVJqqkNOp2/OfamI51yYsmP2vJayPK8vJiZGH330kR588EFde+21Kioq0jnnnKO//e1vioiI0I033qglS5boqquu0m+//aY5c+bo9ttvL7WNhg0b6sMPP1R6erouueQSxcbG6oYbbtD06dNLnttTBv3ksVQ05pPbli1bprFjx+rOO+/Uvn371LJlS11xxRVKTExUVFSUDh48qNtvv12//PKLmjZtqrS0NE2aNEkREREqLi7WqFGjtGvXLsXF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bd68WVu2bNHixYtVXFysZ555xucDRc2ccor585tvpJUrwy9A/Pqr+fOKK6Tu3YM6FAAAANhIjQOUx5EjRxQZaT58wIABPhsQ6s7lMve6SNK2bVKPHuYhbDNnhschbG639N135vV9+8zb4RQeAQAA4D81Ogdq586dJdc94akq2dnZNR8R6sTlkgYNkvbvL92enW22u1zBGVeguFxS27bSF1+Yt595xrxt99cNAACAwKhRgLrooot011136QvPt9MKHDp0SK+88orOPfdcufjWGlBut5SeXvE6UJ620aPNfnbkCY+7dpVuD5fwCAAAAP+r0SF827dv1+TJk9WnTx9FRUWpc+fOatWqlWJiYvTrr79q27Zt+uabb9S5c2c9++yz6tu3r7/GjQqsWVM+PJzMMKSsLLOf3c4Lqi48OhxmeBwwgMP5AAAAUHs12gMVHx+vqVOnavfu3XrhhRd0xhlnaP/+/frhhx8kSbfeeqs2bdqkdevWEZ6CICfHt/1CSU3CIwAAAFBbtSoiERMTo169eiktHCoShBBvq8fbscp8OIdHAAAABE6NF9L1SE1N1Z49e3w5FtRRaqpZbc/hqPh+h0NKSTH72U04h0cAAAAETq0DVOfOnXXJJZfo22+/LdW+efNm9evXr84DQ805nWapcql8iPLcnjHDnucAhXN4BAAAQODUOkC9+uqrGj58uC6//HKtXbtW33//vW666SZ17txZ0dHRvhwjaiAtTVq0SEpKKt2enGy22/Woy5PDY1l2D48AAAAInFoHKEkaP368HnzwQfXq1Uvnnnuujh07pg0bNmjx4sU12s7q1avVv39/tWrVSg6HQ0uWLPH6sevWrVNkZKTOP//8mg3extLSpB07JM+OwOHDpcxM+4YnD094POWU0u12D48AAAAInFoHqJycHN1///164okndM455ygqKkqDBw/WBRdcUONtHTlyRB07dtSsWbNq9LhDhw5p6NChuuqqq2r8nHbndErnnmtej4sLnz0vaWlSRoZ5vVs3acWK8AiPAAAACIxaVeGTpFNPPVVnnXWWFi5cqGuuuUYffvihbrrpJu3atUsPP/xwjbbVt2/fWpU9/8Mf/qAhQ4bI6XRWu9cqPz9f+fn5Jbdzc3MlSYWFhSosLKzxc/uaZwy+HEtcXIQkpzZsKNbHHxfr8suNsAhS+/ebr/vCC93q2rVY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I488oiFDhiguLs7vz0eAsgCHw1HqtmEY5doQ2u677z59/fXXWrt2bbCHAh/IyspSenq6PvroI8XExAR7OPCx4uJide7cWZMnT5YkderUSd98841eeOEFApQNLFiwQG+99ZbmzZun9u3ba8uWLRo9erRatWqlYcOGBXt48DG+Y9lfYWGhBg8erOLiYj3//PMBeU4CVBA1bdpUTqez3N6mvXv3lvuLCULXqFGj9P7772v16tVKTk4O9nDgA5s2bdLevXt14YUXlrS53W6tXr1as2bNUn5+vpxOZxBHiLpITEzUOeecU6rt7LPP1nvvvRekEcGXxowZo0ceeUSDBw+WJHXo0EE///yzpkyZQoCykZYtW0oy90QlJiaWtPMdy14KCwt10003KTMzU59++mlA9j5JnAMVVPXq1dOFF16o5cuXl2pfvny5LrvssiCNCr5iGIbuu+8+uVwuffrpp2rXrl2whwQfueqqq7R161Zt2bKl5NK5c2fdeuut2rJlC+EpxHXt2rXckgPff/+92rRpE6QRwZeOHj2qiIjSX3+cTidlzG2mXbt2atmyZanvWAUFBVq1ahXfsWzCE55++OEHffzxx0pISAjYc7MHKsgyMjJ02223qXPnzurSpYtefvll7dy5U/fcc0+wh4Y6GjlypObNm6elS5eqUaNGJXsaGzdurPr16wd5dKiLRo0alTuXrUGDBkpISOAcNxt44IEHdNlll2ny5Mm66aab9MUXX+jll1/Wyy+/HOyhwQf69++vp556Sq1bt1b79u21efNmTZ8+XcOHDw/20FBDeXl5+u9//1tyOzMzU1u2bFF8fLxat26t0aNHa/LkyTr99NN1+umna/LkyYqNjdWQIUOCOGp4q6r5bdWqlQYNGqQvv/xS//jHP+R2u0u+Z8XHx6tevXr+HZyBoPvb3/5mtGnTxqhXr55xwQUXGKtWrQr2kOADkiq8zJkzJ9hDgx9069bNSE9PD/Yw4CN///vfjXPPPdeIjo42zjrrLOPll18O9pDgI7m5uUZ6errRunVrIyYmxjj11FONsWPHGvn5+cEeGmpoxYoVFf4/O2zYMMMwDKO4uNgYP3680bJlSyM6Otq44oorjK1btwZ30PBaVfObmZlZ6fesFStW+H1srAMFAAAAAF7iHCgAAAAA8BIBCgAAAAC8RIACAAAAAC8RoAAAAADASwQoAAAAAPASAQoAAAAAvESAAgAAAAAvEaAAAAAAwEsEKACAT91+++0aOHBgpffPnTtXTZo0Cdh4As3hcGjJkiVh99wAEC4IUABgc927d9fo0aMD9rjq3Hzzzfr+++8tMZa6mDBhgs4///xy7Tk5Oerbt69tnxsAwl1ksAcAAAgv9evXV/369YM9jEoVFBSoXr16tX58y5YtfTia0HluAAgX7IECABu7/fbbtWrVKs2cOVMOh0MOh0M7duyQJK1atUoXX3yxoqOjlZiYqEceeURFRUVVPs7tdmvEiBFq166d6tevrzPPPFMzZ86s0ZjKHsLn2Zvy5ptvqm3btmrcuLEGDx6sw4cPV/satm3bpn79+qlhw4Zq0aKFbrvtNu3fv79k24cPH9att96qBg0aKDExUX/5y1/K7c1q27atnnzySd1+++1q3Lix7rrrLknSww8/rDPOOEOxsbE69dRT9fjjj6uwsLDkNUycOFFfffVVyZjmzp0rqfxhdFu3btWVV16p+vXrKyEhQXfffbfy8vJKzdHAgQM1depUJSYmKiEhQSNHjix5roreP2+ee8eOHXI4HHr33XeVmpqq+vXr66KLLtL333+vDRs2qHPnzmrYsKH69Omjffv2lXqOOXPm6Oyzz1ZMTIzOOussPf/8817NLQCEBQMAYFu//fab0aVLF+Ouu+4ycnJyjJycHKOoqMjYtWuXERsba9x7773G9u3bjcWLFxtNmzY1xo8fX+XjCgoKjHHjxhlffPGF8dNPPxlvvfWWERsbayxYsKDkOYcNG2YMGDCg0jHNmTPHaNy4ccnt8ePHGw0bNjTS0tKMrVu3GqtXrzZatmxpPPbYY1WOZffu3UbTpk2NRx991Ni+fbvx5ZdfGr169TJ69OhRsu0777zTaNOmjfHxxx8bW7duNa6//nqjUaNGRnp6ekmfNm3aGHFxccazzz5r/PDDD8YPP/xgGIZhPPHEE8a6deuMzMxM4/333zdatGhhPP3004ZhGMbRo0eNBx980Gjfvn3JmI4ePWoYhmFIMhYvXmwYhmEcOXLEaNWqVclr++STT4x27doZw4YNK/V+xcXFGffcc4+xfft24+9//7sRGxtrvPzyyxW+f94+d2ZmpiHJOOuss4wPPvjA2LZtm3HppZcaF1xwgdG9e3dj7dq1xpdffmmcdtppxj333FOy/ZdfftlITEw03nvvPeOnn34y3nvvPSM+Pt6YO3dupXMKAOGEAAUANtetW7dSgcEwDOOxxx4zzjzzTKO4uLik7W9/+5vRsGFDw+12V/q4itx7773GDTfcUHK7NgEqNjbWyM3NLWkbM2aMcckll1T5Gh5//HGjd+/epdqysrIMScZ3331n5ObmGlFRUcbChQtL7v/tt9+M2NjYcgFq4MCB1b7OZ555xrjwwgtLjbtjx47l+p0cYl5++WXjlFNOMfLy8kru/+c//2lEREQYe/bsMQzDfL/atGljFBUVlfS58cYbjZtvvrnSsXjz3J4A9eqrr5bcP3/+fEOS8cknn5S0TZkyxTjzzDNLbqekpBjz5s0rtd0nnnjC6NKlS6XjAYBwwjlQABCGtm/fri5dusjhcJS0de3aVXl5edq1a5dat25d6WNffPFFvfrqq/r555917NgxFRQUVFjQoCbatm2rRo0aldxOTEzU3r17q3zMpk2btGLFCjVs2LDcfT/++KOOHTumwsJCXXzxxSXtjRs31plnnlmuf+fOncu1LVq0SDNmzNB///tf5eXlqaioSHFxcTV5Wdq+fbs6duyoBg0alLR17dpVxcXF+u6779SiRQtJUvv27eV0Okv6JCYmauvWrTV6rsqcd955Jdc9z9ehQ4dSbZ73et++fcrKytKIESNKDmWUpKKiIjVu3Ngn4wGAUEeAAoAwZBhGqfDkaZNUrv1k7777rh544AFNmzZNXbp0UaNGjfTss8/q888/r9N4oqKiSt12OBwqLi6u8jHFxcXq37+/nn766XL3JSYm6ocffijZ1sk8r/NkJwccSfr3v/+twYMHa+LEibr66qvVuHFjvfPOO5o2bZpXr+fk56rs/Ty5vTav31snb9vznGXbPM/l+fnKK6/okksuKbWdkwMeAIQzAhQA2Fy9evXkdrtLtZ1zzjl67733Sn3BX79+vRo1aqSkpKRKH7dmzRpddtlluvfee0vafvzxRz+/gorHcsEFF+i9995T27ZtFRlZ/r+z3/3ud4qKitIXX3yhlJQUSVJubq5++OEHdevWrcrnW7dundq0aaOxY8eWtP3888/Vjqmsc845R6+//rqOHDlSEtLWrVuniIgInXHGGVU+tirePHdttGjRQklJSfrpp5906623+nz7AGAHVOEDAJtr27atPv/8c+3YsUP79+9XcXGx7r33XmVlZWnUqFH69ttvtXTpUo0fP14ZGRmKiIio9HGnnXaaNm7cqA8//FDff/+9Hn/8cW3YsCEor2HkyJE6ePCgbrnlFn3xxRf66aef9NFHH2n48OFyu91q1KiRhg0bpjFjxmjFihX65ptvNHz4cEVERFS5l02STjvtNO3cuVPvvPOOfvzxRz333HNavHhxuTFlZmZqy5Yt2r9/v/Lz88tt59Zbb1VMTIyGDRum//znP1qxYoVGjRql2267reRwutq+H9U9d21NmDBBU6ZM0cyZM/X9999r69atmjNnjqZPn+6z5wCAUEaAAgCbe+ihh+R0OnXOOeeoWbNm2rlzp5KSkrRs2TJ98cUX6tixo+655x6NGDFCf/rTn6p83D333KO0tDTdfPPNuuSSS3TgwIFSe6MC+RpatWqldevWye126+qrr9a5556r9PR0NW7cuCQETp8+XV26dNG1116rnj17qmvXriXluasyYMAAPfDAA7rvvvt0/vnna/369Xr88cdL9bnhhhvUp08f9ejRQ82aNdP8+fPLbSc2NlYffvihDh48qIsuukiDBg3SVVddpVmzZtXp/fDmuWvrzjvv1Kuvvqq5c+eqQ4cO6tatm+bOnat27dr57DkAIJQ5jIoOBgcAwIaOHDmipKQkTZs2TSNGjAj2cAAAIYhzoAAAtrV582Z9++23uvjii3Xo0CFNmjRJkrmHCQCA2iBAAQBsberUqfruu+9Ur149XXjhhVqzZo2aNm0a7GEBAEIUh/ABAAAAgJcoIgEAAAAAXiJAAQAAAICXCFAAAAAA4CUCFAAAAAB4iQAFAAAAAF4iQAEAAACAlwhQAAAAAOAlAhQAAAAAeOn/ARFl7KTuEp56AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#number_times = 100\n",
    "#x_init = 3\n",
    "#max_iterations = 10\n",
    "#mean_duration  = 10\n",
    "#success =0\n",
    "\n",
    "#for n in range(number_times):\n",
    "#x_HD, t_HD = HD( max_iterations, mean_duration, x_init )\n",
    "#    if( np.abs( x_HD[-1] + 1.8 ) < 1 ):\n",
    "#        success += 1\n",
    "\n",
    "#print(\"==successful rate === \", success/number_times)\n",
    "        \n",
    "plt.figure(figsize=(10, 6))\n",
    "plt.plot(t_HD, x_HD, '-o', color = 'b', label=r'frictionless HD (10 resets)')\n",
    "\n",
    "#plt.plot(t_no_reset, x_no_reset_2, '-x', color = 'r', label=r'frictionless HD (no reset)')\n",
    "#plt.plot(t_HD_a, x_HD_2_a, '-o', color = 'b', label=r'frictionless HD (10 resets)')\n",
    "#plt.plot(t_HD_b, x_HD_2_b, '-v', color = 'y', label=r'frictionless HD (30 resets)')\n",
    "#plt.plot(t_GD,  x_GD_2, '-<', color = 'k', label=r'Gradient Flow')\n",
    "#plt.plot(t_NAG, x_NAG_2, '-1', color = 'c', label=r'NAG Flow')\n",
    "\n",
    "plt.title(r'x')\n",
    "plt.xlabel(r'total integration time')\n",
    "#plt.yscale(\"log\")\n",
    "plt.ylabel(r'$x(t)$')\n",
    "plt.grid(True)\n",
    "plt.legend()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "controversial-winter",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = np.linspace(-3, 3, 400)\n",
    "y = f(x)\n",
    "\n",
    "# Create the plot\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.plot(x, y, label=r'$f(x) = 5*(x^2 - 1)^2 + 5x$', color='blue')\n",
    "\n",
    "plt.plot(x_HD, f(x_HD), '-.>', markevery=100, color = 'r', label=r'Idealized Randomized HD')\n",
    "\n",
    "plt.annotate('Start',fontsize=22, xy=(x_HD[0], f(x_HD[0]) ), xytext=(x_HD[0]-0.5, f(x_HD[0])+0.5),\n",
    "             arrowprops=dict(facecolor='green', shrink=0.05))\n",
    "plt.annotate('End',fontsize=22, xy=(x_HD[-1], f(x_HD)[-1] ), xytext=(x_HD[-1]+0.5, f(x_HD[-1])-0.5),\n",
    "             arrowprops=dict(facecolor='olive', shrink=0.05))\n",
    "\n",
    "\n",
    "#plt.title('Plot of the function $f(x) = (x^2 - 1)^2$')\n",
    "plt.xlabel('x',fontsize=20)\n",
    "plt.ylabel('f(x)',fontsize=20)\n",
    "\n",
    "plt.legend(fontsize=20)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "\n",
    "\n",
    "plt.axhline(0, color='black', linewidth=0.5)\n",
    "plt.axvline(0, color='black', linewidth=0.5)\n",
    "plt.grid(True)\n",
    "\n",
    "myname = \"illustrate2\"\n",
    "hi = myname + \".png\"\n",
    "plt.savefig(hi)\n",
    "plt.show();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "adjusted-traffic",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import copy\n",
    "\n",
    "from AdaHD_Optimizer import AdaHD, HD\n",
    "\n",
    "# Define the function f(x)\n",
    "def f(x):\n",
    "    return  (x**2 -  3)**2 + 2*x\n",
    "\n",
    "num_run = 1\n",
    "\n",
    "x_run = []\n",
    "for ite in range(num_run):\n",
    "    \n",
    "    x = 2.5\n",
    "    x = torch.tensor(x, requires_grad=True)\n",
    "    \n",
    "#     optimizer = HD([x], lr=0.01, mean_duration=0.1, mu=0.0)\n",
    "    optimizer = AdaHD([x], lr=0.01, betas=(1, 0.999), mean_duration=0.2, mu=0.0)\n",
    "#     optimizer = torch.optim.Adam([x], lr=0.01, betas=(0.9, 0.999))\n",
    "#     optimizer = torch.optim.SGD([x], lr=0.01, momentum=0.9, dampening=0.0, nesterov=False)\n",
    "\n",
    "    x_tra = [copy.deepcopy(x.data)]\n",
    "    max_iteration = 2000\n",
    "\n",
    "    for i in range(max_iteration):\n",
    "        optimizer.zero_grad()\n",
    "        loss = f(x)\n",
    "        loss.backward()\n",
    "\n",
    "    #     x.grad += 1 * torch.randn_like(x)\n",
    "        optimizer.step()\n",
    "\n",
    "        x_tra.append(copy.deepcopy(x.data))\n",
    "\n",
    "    x_tra = torch.stack(x_tra)\n",
    "    x_run.append(x_tra)\n",
    "\n",
    "x_run = torch.stack(x_run, dim=0)\n",
    "x_run_mean = x_run.mean(dim=0)\n",
    "x_run_std = x_run.std(dim=0)\n",
    "\n",
    "\n",
    "x_axis = np.arange(max_iteration+1)\n",
    "\n",
    "plt.figure(figsize=(10, 6))\n",
    "plt.plot(x_axis, x_run_mean, '-o', markevery=10, color = 'b', label=r'HD')\n",
    "plt.fill_between(x_axis, x_run_mean+x_run_std, x_run_mean-x_run_std, color='b', alpha=0.2)\n",
    "plt.title(r'X Trajectory')\n",
    "plt.xlabel(r'Number of Steps')\n",
    "plt.ylabel(r'$x(t)$')\n",
    "plt.grid(True)\n",
    "plt.legend()\n",
    "\n",
    "myname = \"HD_x_1\"\n",
    "hi = 'pictures/' + myname + \".png\"\n",
    "# plt.savefig(hi)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "northern-addiction",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_range = np.linspace(-3, 3, 400)\n",
    "y = f(x_range)\n",
    "\n",
    "# Create the plot\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.plot(x_range, y, label=r'$f(x)$', color='blue')\n",
    "\n",
    "plt.plot(x_tra, f(x_tra), '-.>', markevery=10, color = 'r', label=r'Adam')\n",
    "\n",
    "plt.annotate('Start',fontsize=22, xy=(x_tra[0], f(x_tra[0]) ), xytext=(x_tra[0]-0.5, f(x_tra[0])+0.5),\n",
    "             arrowprops=dict(facecolor='green', shrink=0.05))\n",
    "plt.annotate('End',fontsize=22, xy=(x_tra[-1], f(x_tra)[-1] ), xytext=(x_tra[-1]+0.5, f(x_tra[-1])-0.5),\n",
    "             arrowprops=dict(facecolor='olive', shrink=0.05))\n",
    "\n",
    "\n",
    "#plt.title('Plot of the function $f(x) = (x^2 - 1)^2$')\n",
    "plt.xlabel('x',fontsize=20)\n",
    "plt.ylabel('f(x)',fontsize=20)\n",
    "\n",
    "plt.legend(fontsize=20)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "\n",
    "\n",
    "plt.axhline(0, color='black', linewidth=0.5)\n",
    "plt.axvline(0, color='black', linewidth=0.5)\n",
    "plt.grid(True)\n",
    "\n",
    "myname = \"Adam_0.999\"\n",
    "hi = 'pictures/' + myname + \".png\"\n",
    "plt.savefig(hi)\n",
    "plt.show();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "grateful-investigator",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import copy\n",
    "\n",
    "from AdaHD_Optimizer import AdaHD, HD\n",
    "\n",
    "def loss_function(x):\n",
    "    return x[0]**4 + 10*(x[1] - x[0]**2)**2\n",
    "\n",
    "\n",
    "num_run = 10\n",
    "\n",
    "x_initial = torch.randn(2, requires_grad=True, dtype=torch.double)\n",
    "\n",
    "dist_run_GD = []\n",
    "dist_run_GDM = []\n",
    "dist_run_HD = []\n",
    "dist_run_AdaHD = []\n",
    "dist_run_Adam = []\n",
    "\n",
    "for ite in range(num_run):\n",
    "    \n",
    "    x_GD = copy.deepcopy(x_initial)\n",
    "    x_GDM = copy.deepcopy(x_initial)\n",
    "    x_HD = copy.deepcopy(x_initial)\n",
    "    x_Adam = copy.deepcopy(x_initial)\n",
    "    x_AdaHD = copy.deepcopy(x_initial)\n",
    "    \n",
    "    opt_solution = torch.tensor([0.0, 0.0], requires_grad=False, dtype=torch.double)\n",
    "    \n",
    "    optimizer_HD = HD([x_HD], lr=0.0001, mean_duration=0.02, mu=0.0)\n",
    "    optimizer_AdaHD = AdaHD([x_AdaHD], lr=0.0001, betas=(1, 0.999), mean_duration=0.02, mu=0.0)\n",
    "    optimizer_Adam = torch.optim.Adam([x_Adam], lr=0.0001, betas=(0.9, 0.999))\n",
    "    optimizer_GDM = torch.optim.SGD([x_GD], lr=0.0001, momentum=0.9, dampening=0.0, nesterov=False)\n",
    "    optimizer_GD = torch.optim.SGD([x_GD], lr=0.0001, momentum=0.0, dampening=0.0, nesterov=False)\n",
    "\n",
    "    dist_tra_GD = []\n",
    "    dist_tra_GDM = []\n",
    "    dist_tra_HD = []\n",
    "    dist_tra_Adam = []\n",
    "    dist_tra_AdaHD = []\n",
    "    \n",
    "    max_iteration = 5000\n",
    "\n",
    "    for i in range(max_iteration):\n",
    "        \n",
    "        dist_tra_GD.append(torch.norm(x_GD.data - opt_solution))\n",
    "        optimizer_GD.zero_grad()\n",
    "        loss = loss_function(x_GD)\n",
    "        loss.backward()\n",
    "        optimizer_GD.step()\n",
    "        \n",
    "        dist_tra_GDM.append(torch.norm(x_GDM.data - opt_solution))\n",
    "        optimizer_GDM.zero_grad()\n",
    "        loss = loss_function(x_GDM)\n",
    "        loss.backward()\n",
    "        optimizer_GDM.step()\n",
    "        \n",
    "        dist_tra_HD.append(torch.norm(x_HD.data - opt_solution))\n",
    "        optimizer_HD.zero_grad()\n",
    "        loss = loss_function(x_HD)\n",
    "        loss.backward()\n",
    "        optimizer_HD.step()\n",
    "        \n",
    "        dist_tra_Adam.append(torch.norm(x_Adam.data - opt_solution))\n",
    "        optimizer_Adam.zero_grad()\n",
    "        loss = loss_function(x_Adam)\n",
    "        loss.backward()\n",
    "        optimizer_Adam.step()\n",
    "        \n",
    "        dist_tra_AdaHD.append(torch.norm(x_AdaHD.data - opt_solution))\n",
    "        optimizer_AdaHD.zero_grad()\n",
    "        loss = loss_function(x_AdaHD)\n",
    "        loss.backward()\n",
    "        optimizer_AdaHD.step()\n",
    "\n",
    "        \n",
    "\n",
    "    dist_tra_GD = torch.stack(dist_tra_GD)\n",
    "    dist_run_GD.append(dist_tra_GD)\n",
    "    \n",
    "    dist_tra_HD = torch.stack(dist_tra_HD)\n",
    "    dist_run_HD.append(dist_tra_HD)\n",
    "    \n",
    "    dist_tra_Adam = torch.stack(dist_tra_Adam)\n",
    "    dist_run_Adam.append(dist_tra_Adam)\n",
    "    \n",
    "    dist_tra_AdaHD = torch.stack(dist_tra_AdaHD)\n",
    "    dist_run_AdaHD.append(dist_tra_AdaHD)\n",
    "\n",
    "dist_run_GD = torch.stack(dist_run_GD, dim=0)\n",
    "dist_run_mean_GD = dist_run_GD.mean(dim=0)\n",
    "dist_run_std_GD = dist_run_GD.std(dim=0)\n",
    "\n",
    "dist_run_HD = torch.stack(dist_run_HD, dim=0)\n",
    "dist_run_mean_HD = dist_run_HD.mean(dim=0)\n",
    "dist_run_std_HD = dist_run_HD.std(dim=0)\n",
    "\n",
    "dist_run_Adam = torch.stack(dist_run_Adam, dim=0)\n",
    "dist_run_mean_Adam = dist_run_Adam.mean(dim=0)\n",
    "dist_run_std_Adam = dist_run_Adam.std(dim=0)\n",
    "\n",
    "dist_run_AdaHD = torch.stack(dist_run_AdaHD, dim=0)\n",
    "dist_run_mean_AdaHD = dist_run_AdaHD.mean(dim=0)\n",
    "dist_run_std_AdaHD = dist_run_AdaHD.std(dim=0)\n",
    "\n",
    "x_axis = list(range(max_iteration))\n",
    "\n",
    "plt.figure(figsize=(10, 6))\n",
    "plt.plot(x_axis, dist_run_mean_GD, '-o', markevery=100, color = 'red', label=r'GDM')\n",
    "plt.plot(x_axis, dist_run_mean_HD, '-x', markevery=100, color = 'orange', label=r'HD')\n",
    "plt.plot(x_axis, dist_run_mean_Adam, '-v', markevery=100, color = 'b', label=r'Adam')\n",
    "plt.plot(x_axis, dist_run_mean_AdaHD, '->', markevery=100, color = 'royalblue', label=r'AdaHD')\n",
    "plt.fill_between(x_axis, dist_run_mean_GD+dist_run_std_GD, dist_run_mean_GD-dist_run_std_GD, color='red', alpha=0.2)\n",
    "plt.fill_between(x_axis, dist_run_mean_HD+dist_run_std_HD, dist_run_mean_HD-dist_run_std_HD, color='orange', alpha=0.2)\n",
    "# plt.fill_between(x_axis, dist_run_mean_Adam+dist_run_std_Adam, dist_run_mean_Adam-dist_run_std_Adam, color='blue', alpha=0.2)\n",
    "# plt.fill_between(x_axis, dist_run_mean_AdaHD+dist_run_std_AdaHD, dist_run_mean_AdaHD-dist_run_std_AdaHD, color='royalblue', alpha=0.2)\n",
    "plt.title(r'Optimality Gap')\n",
    "plt.xlabel(r'Number of Steps')\n",
    "plt.ylabel(r'Distance')\n",
    "plt.yscale('log')\n",
    "plt.grid(True)\n",
    "plt.legend()\n",
    "\n",
    "myname = \"Experiment1_c\"\n",
    "hi = 'pictures/' + myname + \".png\"\n",
    "# plt.savefig(hi)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "surface-swaziland",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYsAAAEgCAYAAABFO1+mAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABRKElEQVR4nO2dd5gkVdX/P6fz5LCzO5vYDCwsmSVJWnKQJCogimJAUdFXDJgRMbw/8FXMWcSEa0KiSHSBJQnLknZhgU3sbN7JqafT/f1xq2d6ejrNTM9098z5PE891XXrVtW91d31rXPODWKMQVEURVEy4Sp0ARRFUZTiR8VCURRFyYqKhaIoipIVFQtFURQlKyoWiqIoSlZULBRFUZSsqFiUKCJynYgYZ4mJSKuIPCMi3xKR6Ul55zn5zsnx3D7n/IeMSeHHkLEqu4jMEZHfiMhWEekTkU0i8gMRaRjh+S4SkctTpK8Qkb+PusC5l+MWEXk2h3yXi8gqEel0fmurReR7I7jeJhH5v2EeM835TuclpS9zftcHDLccyvBRsSht2oFjgLcAlwC3AZcBL4nI4Qn5tjv5VuZ4Xh/wNeCQvJV0/Mh72UVkCbAKOBr4MnA68L/A24CnRWTmCE57EXB5ivSPAV8cWUnHBhH5IvBr4D7gQuC9wB3AeeNUhGnY73ReUvpz2N/1+nEqx6TGU+gCKKMiYox5KmH7PhH5GfAo8BcR2dcYEzXG9AFPpT6FkgkREeCPQCtwjDGmw9n1iIjcDbwI/BS4IB/XM8aszcd58sxVwC+MMV9KSLtLRL5eqAIBON+F/q7HCbUsJhjGmDbgGmAhcBqkdkOJyHmOW6HbcSs8LSInOrs7nfVvE1xd85zj/p+IvCQiXSLSJCJ/SuH22iQi/yciVzt5WkVkuYjUJuWbIiK/EJHtIhIUkXUi8qmE/S4R+YKIvOG4fl4TkfdluQWZyt4gIr8TkWYR6XFcPkuznO8ErJXyzQShAMAYsxX4IXBewjXirpHTReRu5/6+KSJXJtTrFuDtwIkJZbzO2TfIDeW4X/aIyFEi8qyI9IrIShGZ77hnbne+i1dE5OSk+/teJ2+L8x38J4f6pqIW2JGcaJKGfxjJ/U3ldkt0Lzn39SVn13/i9ys5X8Kx5SLyQxHZ4fymnhGR01NdU0QudX5bHSJyr4jMHsY9mXSoWExM/gNEsG6TIYjIQuDvwMPAucC7gbuBeidL/KHzTayZfwzWlQXWJfBt4K3Ap4AFwMMi4k66zEXAKcCHgc8D5zjHxctQBqzAvpF/Azgb+C6Q6NL5EfAV4JfO9f4J3CyZYy+Zyn47cAbwWeBi7O//PyKyKMP5TnDWd6TZfzsgwHFJ6b/BWh0XAvcCP0so9zew39HqhDL+OkMZyrH34CbgXcAc4A/An7GuxQuBrcDfRKQ84bh5wO+BdwKXAk3AoyKyIMO1UvEc8AkReZ+ITMmQ73aGf3+zsR37+wT4OAP3Kx2/At4PfAvrJtwC3CMiyd/PUViL6TPY3+hh2HuspMMYo0sJLsB1wJ4M+7cDP3M+zwMMcI6z/Q6gOcOxlU7+y7OUwQ3McvKekJC+CetH9iSkfR/YkbD9ESAGHJLm3Iuc/e9LSv898Mxwyw6c6aSfmJBWAezGuljSne/nQGuG/bXOeT/vbC9ztn+ZlO8B4KmE7b8DK1KcbwXw96TvObncH3PSrk1I299JOytNOV1Yt/OrScfdAjyb5Xs+CNjgnD8GrAGuB6qHe3+d38b/patv0j08wNk+wNleliXffsm/GafeLwP3JV2zHahLSPuUc66y4f4XJ8uilsXERTLsewmocVwGp4tIRc4nFTlLRJ4QkXas9dLk7NonKet/jDGRhO21wDQR8TnbJwOrjTHPp7nUKdg//j9FxBNfgIeAQ1JYMtk4EthtjHkknmCM6cZaVMlvncMh3Uic/0zavg04fATlBggBjyVsv+GsH06RNiueICL7icg/RWQnEAXCwL4M/a4yYox5EfsgPg8bnxHgq8CzIlLpZBur+zscjnDK9reEMsSc7eQyPGOMaU3YjseKZqGkRMViAiIiAWAKsDPVfmPMOuB8rAvpX8AeEblVRKZmOe8RwJ1YgbgM6w6Iu7oCSdnbkrZD2D9yXCymMOAeSkUD1nJpxz7k4sst2DfkGZnKmoIZpL4fOxlwv6ViK1ArItVp9s9LyJfIrhTbHmy9hkun89CLE3LWbfEEY0w8LQAgIlXA/cBewKeB47EP0xcY+l1lxRjTZ4y5yxhzlTFmf+BDwN7AB50sI72/+WQG0GWM6UlRhnIR8SektSXlGXT/lKFoa6iJyUnY7/bJdBmMMfdgfbk12HjA97ExgksynPdtWLfCxcax3UVk7gjL2Ix1NaWjBWu5HIu1MJJJfhhnYzs23pJMo3OtdDzqrM/DtopK5jysdfFYUnrytaZh67Mna0nzwzHAbOA0Y8yr8UTn+x41xpjfiMiNwGInaaT3N8jAC0SckYrLdqBSRMqTBKMR6DG2VaAyQtSymGA4LY5uwLolHsyW3xjTboy5Fes22d9JTveWVQaE40Lh8G5GxkPAoSJyUJr9D2MtixpjzLMpllCa49KV/WmsGywesMYJBr+VzP1PHgWeB77qvK33IyIzgP8B7jDGbE467m0ptlcZY6IJ5RzLt9gyZ93/gBSRtzC0r0JWRGSICDhWaA0D1sRI728TA4IT57Sk7Vzf+p/BCvc7EsogznaufYyUNKhlUdp4RCTuBqoCDgc+im09c2bCg2kQIvIR7Jvnv4FtWHfCO7HBY4wxIRHZCFwkIi9j3/5exAZpPyUi3wfuwnYGfM8Iy/57bOuW+51mo+uA+cA+xpgvGGPWicjPgeXOG+yz2IfFEifPh1KdNF3ZjTH3icjj2P4nX8BaNp/FPlS/k66QxhgjIpdhWy896ZRlE/YB92Wsm+zjKQ49S0S+BTyCba10Gtb1F+dV4HwRuQD7wNxmjNmW8Y4Nj6eALuBXTplnY4Plye6yXHhJRO7AurV2AXOx964H+B3ASO8v9iXlgyJyE3AP1io+IynPm0Av8D4nVhY2xgzpdW6MeUVE/gz82HEbvgFcgf2uPjqCeiuJFDrCrsvIFgZaycRbqLRhH6jfAqYn5Z3H4NZQx2D/mNuwD9ONWGvEn3DM6ViBCDrHznPSr8E2R+zGWi57O/uvSjh2EwktXpy0y518lQlpU7BNHXc513kV+GTCfsG2UlmDfUPejX34vjfLvUlX9qlYkWrFPnweAY7I8X7PwTaH3YZ9090M/ABoSMq3zLnmGdgmsz1YMfhYUr4G7IOyxcl/nZO+gqGtofakucYBSenJ38OZ2JZAvc79ODvF+W8he2uoj2OFIv572QTcCixOypf1/qb5bXzR+U11Yl19cdfeAQl53g285tx7k+4+YF+UfoS1ePqw/4kzkq436B5kuqe6DCzi3ChFUfKAiCzDWiEHGmNeLmxpFCV/aMxCURRFyYqKhaIoipIVdUMpiqIoWVHLQlEURcnKhGk629DQYObNmzeiY7u7u6moyHnEi6JG61J8TJR6gNalWBlNXVatWrXHGJNx9AaYQGIxb948nn0264RfKVmxYgXLli3Lb4EKhNal+Jgo9QCtS7EymrqISHKH0pSUvBtKRM4VkV+2t7cXuiiKoigTlpIXC2MHN/twTU1ehrxRFEVRUlDyYqEoiqKMPRMmZqEoipJvwuEwTU1NBIPBQhclIzU1NbzyyisZ8wQCAWbPno3X6x3RNUpeLETkXODcRYtGM3OjoijKUJqamqiqqmLevHnYAWyLk87OTqqqqtLuN8bQ3NxMU1MT8+fPH9E1Sl4sjDF3AXctXbr0ilzyv/3aJiqmCgsP8+EvF/zRDs7uuJGbnp1Dn3tgfptpZW4+sLhurIqtKEoJEAwGi14ockFEmDJlCrt37x7xOSZdzKJ1T4yt66I8tryXtSv7mNd8L/t23cuirvv687gFZpWXvI4qipIHSl0o4oy2HpPyiWhidizireuiLPD8HmrgyN0/Yk3NOwE7LvaxMyZGZx1FUcaWm19tZVdvyqljBlHq3opJJxbfWXIph9c93r8dM1ZtG8Ov8IVXEjoxNp8Cp2SdaE5RlEnOrHIPzcEo0QzD7I3WW7Fz506uvvpqnnrqKerq6vD5fFxzzTXU1dVx/vnnM2/ePILBII2NjVxzzTWcc845I75WOiadG+pPTVcRjJb1b7tk6DccNmW0z//ieBZLUZQS5dgZFWRz8IzGW2GM4YILLuCEE05gw4YNrFq1iuXLl9PU1ATA8ccfz8qVK1m3bh0//OEPueqqq3jooYdGdK1MlLxYDLcH9/Ptb+FLa28eJBiJBKNlfP7l3/K12w/IZzEVRZmgVHpdHFjvx51GMdwCB9b7qfSO7HH78MMP4/P5uPLKK/vT5s6dyyc+8YkheQ855BCuvfZafvzjH4/oWpkoeTfUcFtDgRWM61/9CV9b/FH87v757AnHvHz7jZ8w9+DTuOws7RGuKMoA/2/1nhEdFzWwurmP1c19Kfd/4dCGjMevWbOGww47LOfrHXbYYXznO5mmPR8ZJW9ZjJRKTztRM1grXWK45iI3/3NJPfU17gKVTFEUJT0f//jHOfjggzniiCNS7h+rOYpK3rIYKWc1/oWAu2dQmlsiVO64BZa8tzCFUhSlaMlmAXSFY/x8TQuRhGe1R+DKJfUjdkEBLFmyhH/84x/92z/5yU/Ys2cPS5cuTZl/9erV7LfffiO+XjompWXhcUNvrIqVcv3Qnd7qoWmKoihZSI5djDZWEefkk08mGAzys5/9rD+tp6cnZd4XX3yRb3zjG3z84x8f1TVTMeksi4WzvRywwM/is+61rqZbvzo4w9KfFKZgiqKUPMfOqOClFhubyFd/LRHh9ttv5+qrr+bGG29k6tSpVFRUcMMNNwDw2GOPcdxxxxEMBpk2bRo//OEPOeWUU0Z93WRKXiyGOzbUr740I3OG22fDpTovuaIowyduXaxu7suLVRFnxowZLF++POW+9vb2rGND5YOSd0ONyXwW4a78nUtRlEnFsTMq2KvCM+FGgSh5sRgtv2v6LL3JfS76RtZETlEUpdLr4t371ObNqigWJlZtRkDbki9wzpNrBye2rylMYRRFUYqUSS8WAZ8Lg4s3IwcNJD6S/3FVFEVRShkVC69t5/ajtj8UuCSKoijFy6QXizKfFYvmcAPMPr/ApVEUpdS44tvb+f6fW2huzz5MeSlT8mIx3IEEkynz2VsQjgBH/CxzZkVRlCTWN4X51xNdvPvarWMiGpWVlYO2b7nlFq666ioArrvuOmbNmsWxxx7L4sWL+ehHP0osFsvr9eOUvFiMtulshd8Ri5ABf8J8FuHOfBRPUZRJQCQKoTBjKhrpuPrqq3n88cdZu3YtL730Eo888siYXKfkxWK0VJfbW9AXMuBK6KP4UP57QCqKMrEppGiEQiGCwSB1dWMzG1/J9+AeLbUVVixCwaRe2y3PFKA0iqIUKyd/7M2c80aiQBTufKyLOx/L3Mn34Z/Oybi/t7eXQw45pH+7paWF8847r3/7pptu4ve//z1btmzhrLPOGpQ3n0x6y6K23A5FHg4liYXLV4DSKIqiDKasrIznn3++f7n++sEDoMbdULt27aK7uzvtsCCjZdJbFjWOZREJQzQawz3zbNj2L5hyVIFLpihKMZHOAshkcXjc4HIJZx1TwWVn1YzpPDler5czzzyTRx99lEsuuSTv55/0YuF1u3B7IBqB9t4Y9XMusmKx+7FCF01RlBJlPEUijjGGJ554YszcUJNeLAA8XisWHT0x6nu3D+wI7oFA5glPFEVR4hRCJOIxi2g0ykEHHcTHPvaxMbmOigVWLPp6ob03CuWzB3ZsuBn2v6ZwBVMUpSQYS5Ho6hocIL/88su5/PLLAdvP4rrrrhuXIcpLXiyGO59FKrxeu+7ojcE+l8CTl9mE9rXpD1IURWFgQrXxsiQKRcm3hsrHfBZer20J1dkTs30tvM65Nv4OYpF8FFNRlAnKr740g/+5pH5CCwVMALHIB3Gx6Ao63eT9UwZ2RrQnt6IoiooF4HVbseiOd8wLtQ7sjKSeGF1RFGUyoWIBeN3WoujqcyyLWHhgZ0SnWFUURVGxAHyOWHTHxeLomwd2vv7zApRIUZSSJdQOj77NricQKhYMiEVPn+OGmvPOgZ3b/12AEimKUrJsvROaboetd+XldLkOUb733ntz4YUXsnbt2LTiVLEgUSwSxoGvmG/XHa8WoESKopQs6x3PxIabM+fLE/GxoV5//XUuvvhiTj75ZHbv3p3366hYAD6XHUI4mDiYYN1BaXIriqIk8NCpcKsMLHuesOm7Hx+c/tCpY16Uiy++mNNPP51bb7017+cu+U55+cAfF4twgmWx5CvQdMfgZrSKokxebpXc8sVCg9dxdj6U+hyXmqFpCWQbojyZww47jFdfzb9HRMUC8Lttx7u+sCEaM7hdAoFGu9PlL2DJFEWZ7MSHKI9zyy238Oyzz6bNb0xm8RkpJS8WeRnuw+lnEYtARzhGnd8NPqcXd3hitWhQFGWEZLEA2Ho3rHwnRIMDae4AHPc3mHXO2JYtgdWrV7N06dK8n7fkYxZ5Ge7DEYtoFNr7nCkQPZWAQKRbh/xQFCU7oTYQD4gL3GV2LR6bPk784x//4P777+dd73pX3s9d8mKRDzz9loWhLeTELcQF3mr7OdxRoJIpilIyrP+NHfGh9mA44Q67jvSMeauom266qb/p7B//+Ecefvhhpk6dmvfrlLwbKh94nKazsSi0hxImV/fWWDdUuB389QUqnaIoJYG3Bg79Diz+lH3ZbDwZ1n1/1BOp6RDlRUS/GyoCbX0JYuGrgR40bqEoSnZOvH3wtssN+33GLhMAdUOR4IaKGpoTxSI+n8V/ryxAqRRFUYoHFQsGxCIageZglFi86ZlxhKP56QKVTFGUQjNWTVHHm9HWQ8WCATcUUYgaaI1bF/EhPxRFmZQEAgGam5tLXjCMMTQ3NxMIBEZ8Do1ZkOiGstu7e6NMCXjgxDvgXwcNnpdbUZRJw+zZs2lqahqTsZbySTAYzCoEgUCA2bNH/ixTsWBgPou4WOzsjbC4zg9lM21CWOe0UJTJiNfrZf784vcwrFixgkMPPXRMr6FuKAbcUJGIwRjD1m6nE56nwq7DbePasUZRFKXYULEAXC7weiAWs9bF9p6wDXInjgu1+prCFVBRFKXAqFg4lAfsragUIRyDXb1RkIQRIltXF6hkiqIohUfFwqHcb4VhiseGcd7sCiflKO3WEIqiKKNBxcKhzLEspnrdAGzocMaiD0y361qdDElRlMmLioVDmWNZ1CdYFqGogcO+ZzNs+C30bC1U8RRFUQpKyYuFiJwrIr9sbx/d+E3xmEUsArMqPMQMbOoMga9uINPt2t9CUZTJScmLRT7ms4ABy6I3GGNhtQ+AdW0h8NUOztixblTXURRFKUVKXizyRZnf3orePsP+dbbJ7GvtfYR80wdnjPaOd9EURVEKjoqFQ3nAsSz6DLV+N7MrPIRj8FokSSya7ipA6RRFUQqLioXDgGVhh/5YUm+tixeag4MzvnQtmNi4lk1RFKXQqFg49Mcs+mx/iv3r/PhdwpauCM3HrxicOaJjRSmKMrlQsXBItiz8bhcHTbHWxZOxwwZnjiZZG4qiKBMcFQuHZMsC4PCpZQiwtqWP4OIvDmRWsVAUZZKhYuGQSixq/W6W1PuJAQ/WfwE8zoToKhaKokwyVCwcAnE3VHBw8Pq46eW4BF5uDREpn2MTVSwURZlkqFg4pLIswFoXh0yxM1C1R2xnPRULRVEmGyoWDskB7kSOn1FOmUfoMY5YxPrGs2iKoigFR8XCIZ1lAVDmcXHyzAoiLmth9IZ6xrVsiqIohUbFwiE+kGAqywLggHo/Pq8Vi2e3t2KMzm+hKMrkQcXCIZNlASAiTKuwc3J3dW7nv7t0jChFUSYPKhYOfp8Vi2DIEIulFgxv5xoAztrxaZ56s4mN8QmSFEVRJjgqFg5ulxDwCcZAXziNiylhePILmy7j9o2d7AlGxqmEiqIohUPFIoFsrij2/nj/xxl9L9EXM/x1fQftoeh4FE9RFKVgqFgkkK5jXj9H/BimnwaAa+bZzCz30BGKsfyNdjrDKhiKokxcVCwSyGpZAOxjrQuXCXHRwmoay9y09sVY/noHHWphKIoyQVGxSGBALDLMV+GyI9ES7SPgcXHJohqmBtw090X5w2vt7OnVGIaiKBOPohQLEfmZiGwVkXHtzJA4tWpa3I5YOL24yzwu3r13DbMrPHSGY/zx9XY2d2orKUVRJhaeQhcgDX8GrgN2jOdFc3JDuZwhP3Y90p8U8Li4eFENd27q5PX2EMvf6KDCI3RFsmvdtDI3H1hcN6pyK4qijDU5WRYiskhEfiEiL4hIVERWpMm3v4g8JCI9IrJNRK4XEfdwC2WMedQYs3O4x42WbL24gQE3FMCOB/s/el3C2+ZXcfS0MgzkJBRugVnlxarXiqIoA+TqhloCnA285ixDEJE64EHAAOcD1wOfAb4++mKOD4HhWBYA7a8M3iXCslkVXDCvCo9kv54Ax86oGEFJFUVRxpdcX2vvMsbcASAifwcaUuS5EigDLjTGdAAPiEg1cJ2I3OikISIrgdkpjn/IGPPBYdcgj2QaebYfT3nCRmpRWVznpyHg5o+vtxFM00DKLXBgvZ9Kb1GGjRRFUQaR05PKGJPh6dnPWcB9cVFwWI4VkBMTznWcMWZeiqWgQgE5xizcCWKRYTDBhjIP79+3jnQGhloViqKUEjLc0VPjloUxZllS+i7gp8aY65LSu4HrjDHfGXbhRIwxJq1DR0Q+DHwYoLGx8fDly5cP9xIAdHV1UVlZyVOvVXP/8w0cuXc7Zx7anDKvO9bF8TvOBeCN6o/TVPmOjOfeEJjBLl8dSIIuG0NDqI1Fwa0jKm8m4nWZCEyUukyUeoDWpVgZTV1OOumkVcaYpdny5TO6Wge0pUhvdfbljIj8GjjT+dwE/NsY86HkfMaYXwK/BFi6dKlZtmzZ8ErssGLFCpYtW0a3t4v7n29hSsNMli07MHXmWNjaS8CiBXuxaP/M11wajvHzNS0MineL0Baowz13JkdOK8Pvzp8rKl6XicBEqctEqQdoXYqV8ahLvh3mqcwUSZOe/iTGfMgYM9sYI856iFCMBbk1nfXCtBPs50h31nNWel0cWO/H7dhHLqDG5yJi4PEdvfxibSurdvcSTTPSraIoSjGQT7FoBWpTpNeQ2uIoOnIKcAPMOs+uw105nffYGRX9sQuXwGX71PKevWuYVeGhJ2J4oKmbX6xt5dndvYRVNBRFKULyKRavAosTE0RkL6DC2TcmiMi5IvLL9vb2UZ8rJ8sCwOP4BiO5iUXcuoCBFlCzK728Z+8a3ja/ioaAm45wjAebuvn5mhae2tlDXzSXNgWKoijjQz7F4l7gDBGpSki7GOgFHkl9yOgxxtxljPlwTU3NqM8V75TXk27U2TjDFAuw1sVeFZ5BLaBEhH1r/XxwcS0Xzq9iepmH7ohhxbYefvJyKw80ddGSru2toijKOJJTgFtEyrGd8gBmAdUiEm8G9C9jTA/wc+CTwG0icgOwADtkx/eSmtMWLdUVVizau7KIhdcRi3Du1ar0unj3PrUp94kI+9T62bvGx8bOME/u7GFLV4RVu4Os2h1kQbWXwxvKWFDtRWSgcdjNr7ayqzdJTGoO4KnVewYl6ZAiiqKMllxbQ00D/paUFt+eD2wyxrSKyCnAj4G7sHGKm7CCURLUVlmxaOuKYowZ9GAeRNyy2HYPrP8NLMxPFxERYUG1jwXVPnb2RFi1p5e1LX1s6AizoSNMtdfFgVP8HFgfoNbvZla5h+ZglGimbiE6pIiiKHkgp6eIMWYTpO1flphvLXDyKMtUMAI+FwGfEAwZeoKGirIsYgHw9IfyJhaJNJZ7OHtOFctmVvDCniDPNwdpD8V4fEcvj+/oZU6ll31qvFnPo53/FEXJByX/yiki5wLnLlq0KC/nq6l0EWyJ0tYVpaIsTUjHM34deco9Lo6ZXs7RjWVs7grzUnMf69r6eLMrzJtd4YwKrkOKKIqSL0r+KZLPADdAbaUdJDdj3MI7/r0+RYR5VT7OnVfFVQfUc8ZeFcws92TswKJWhaIo+aLkxSLf9MctOjO0Qkq2LHaOWWOvlAQ8Lg5tKOO9+9by0SV1zCxPPQp8hdfFxo4QPWFthqsoyugoeTdUvqmtsg/ets5MI88mva03/xcaT0ydd4yp8bm5cEHN0CFFgPZQjHvetM17Z1d4WFTjY2G1j4aAO33wXlEUJQUqFknUVA60iEpL4gRIAMFxn6dpEPFOfy+29BE1NlaxuNbHrAovr7eHeLMrTFN3hKbuCCu29VDpdTGvysv8Ki/zqnxUZIhppGyemwJtnqsoE5uSF4t8B7hzilkkv5WHWvJy7dFw7IwKXmqx84ILcNKsSiq9Lg6bWkZfNMbGzjBvtIfY2BGiKxzj5ZY+XnbyTytzM7/Kx7wqL7MqvPjcA/XT5rmKosAEEAtjzF3AXUuXLr0iH+erq7Zv2c3tWd6mK+ZC92b7eRid88aKuHWxek+QA6cEBrWA8rtdLK71s7jWjzGG3cEoGztCbOoMs6UrzK7eKLt6e3l6Vy8uYHq5h70qvexV6WXp1LJ+EUqHBtIVZeJT8mKRb6bV2VuyqzWLWLx1DWy5HZ58T1GIBdgH9hs7Wzh2xpS0eUSEaWUeppV5OKoRIjFDU1eYjZ1hNneF2dkTYZuzPL2rF4CAG6LR1EMHa/NcRZkcqFgk0TjFEYuWSOaMngqoWmg/h0c/iGE+qPS6WNK9kUrv3JyP8biEedU+5lXbucX7ojG2dkfY0mWtju09kbRTw8Y5qrE8cwZFUUoeFYskpta6EYE9bVGiUYPbnaHVkLfarovEssgHfrerf8gRgHDMsL07wsNbu9iRItAdNfCLta1MK3Mzs8LLzHIPjeUeGgJuXMNocaXjXClKcaNikYTXI9RXu2luj7K7Lcr0KRlukdfpCFgklsVY4HUJc6q8vGPh0Oa5AtQHXLQEY+zsjbKzN8pqZ59HYGqZh+nlHhrLPDSWu5ka8OBxpRYQDaQrSnFT8v+8fLeGAmist2KxqzWSRSwcy6J3O8Si4ErdOW4ikKp57kH1fs6YU0UoatjRE2FbT5ht3RF29kZoD8XY3hNhe8+AO88FNJS5HfHwMC3gYWqZmzKPa1BrrnRoIF1RCkfJi0W+W0MBTJ/iYe3GEFt3RTgokwYlds777xVw9M35KkJRktw8N/7g9rmt9TGnamBgw2Akxs7eCDt6Itbq6InQ3Bd1Wl5FBwlDpcdFQ5mbOr+bPcGoBtIVpQgpebEYC+bPtA+9jdvCmTNKwoNrw28nvFj0N89t7sv64A54XMyt8jG3ytefFooadvVay2NnT4TdwSh7ghG6IjG6MvWYx7bE2qfWTzhm8KZxZWVDOxgqyshRsUjBvFzFYhJy7IwK9gSjI3IH+dzC7EovsysHLBBjDO2hGLt6I+wJRnmxOUhbaKhwxAz8Zb1tSFDtczHF72ZKwC71fjdTAh4qPJJxGBONiyjKyNF/RQoWzLRvwxu2hYZ3YCwCrol9SzPN+DcSRIRav5tav5t9gIOmBIYE0l3AvCov7eEYrcEoHaEYHSHbKz0Rv0uoTxCQeue8dX4XfrfGRRRlNEzsJ9sIaax3UxEQWjti7G6NMLUuw2066td2AiSwraL86TvEKdnJFEgHiBpDe1+M5r4IzcEozcEoLX1R9gSj9EXNkKB6nHKPUOd3U+V10RaKjVlcRJsAKxMVFYsUuFzCAQv9PL0myAuv93HqkRlu08IPwsvfgu6NEGpVscgD6QLpAG6x1kN9wM3eCVOYGGPoiRia+6K0BKM0ByO0hWK09kVp64vSEzH0RDJ3tIwZe/4XmoPU+FzU+NxUe124hxEjUVeXMlEp+V/sWDSdBTh4nwBPrwny/OtBTj0yi1siMM2KRXAXVOW3HJORTONcpUNEqPAKFV4XcyoHTzdrjKEzHKOtL0ZrKMqq3b0pA90GeHZPcEh6ldfVLx41Phc1fndaMVFXlzJRKXmxGIumswCH7G2HIV/1ShBjTOb5H8qm23VwRz6LMKnJZZyrXBERqn1uqn1u5uBlYbVvSFzELbBsZjnBqA24t4eitPfF6AwPLE3dqS2TZDGZUe5ha3eEVO278tUEWFt2KeNNyYvFWLHPHB9TatzsbIny2psh9p3rT5854IhF95vjU7hJwEjGuRrOuVPFRY6YNnSMq6gxdMbFI3mdo5gkEjN2PK4X9gSp8rmo8rqo9tkA/HBQd5cy3ugvKQ0ul3DCoWX8c0UXK1b1ZBaLmiV2vfkvsPhT41I+ZXRkiosk4k5orZWKaMxxcTki0hGKOi21QnSFhz7JDfDM7qGuLr9LBolHpddFlddNpdfVv5R7pH+8rfFwd2mwXklExSIDyw4r558runjwmR4+eH4tnnSDCk450q4LPGOekjvD6WCYCbcrtZh0hWMpXV0nzCinL2roCMfoDFmLpCMUpS9m6AvaVl3pEOy86pVeF5Ue6/Zq6Ru7Hu9qvSiJ6LecgQMW+pk73cPmHREeW93DSUvTvKXV7G/XwZ1gzNCZ9JSiZDQdDLORztWVajh3YwzBqKEjQTy6wjG7RGL9n3sipv9zNqIGtvZE+MeGDiq9Lio8Liq8Qrkn/tmufRlGVS6Y9ZICtV4Kj4pFBkSEC06s4gd/aeW2FZ3pxcJTCe4yiPZApAu8VeNbUGVE5LuDYTK5urpEhDKPUOZx0ZjhfNGYodsRj05HNF5sDrIzzcM2Pg5XJrwu+sVjQEiECo+Lcq+L+VU+1neExixYr9ZL6aDfQBZOP6qCX9/ZxpoNIZ5bF+SwfQNDM4lAoBG6N1nrQsVCYWRNgDPhdg206oqzb61/iLvLI/DuvWuIQb+w9IRjdEdidIet4HRHbFo4Bm2hWMohVrIRM+AS4b+7ein3WKul3OOizPmcyxhe49XUWOMvo0fFIgtlARcXn1rNzXe1c/OdbRz62cbUzWgD061Y9O7QvhZKP/lsApyKVO6uA+v9zKjwZj3WGEMoZgYEJC4okRg9CWl7ghFSaYkBVqXolxLH64IyR0DKPUKZ2zUgKl4XZW77ee8aH+vaxs56AbVg8kHJ35mx6pSXyNtPquK2/3SydmOIx57v5YRDU0wjWuY4EDTIrSQwlk2A4+Tq7kpGRPC7Bb8b6kk/F0uqYL1L4PjpZcQQehwrpSdi6I3GnN7y1moJO+N4jZSYsRbVM7t6KfMIAbe1XMqctd8tOc3IqPGX0VPyYjFWnfISKQu4eN85NfxgeSs//lsrS/cLUB5IetMJJHTMm+ATISnFRb5admU7f3Kw/pjp6R+scaslLhy9zjrd545QLKVlYYBnUzQ1TiTgln4BCSStE4VlYbWP19s1/jJSSrPUBeCc4yq576luXt0U4jd3tvGJi+oHZwg4lsWzV8FzV8Pxt8Oss8e9nMrkZCxbdsXPPxzrJdFqqUvTRyWRrnCMn61pGfSgdQkcO70MY4TeaIxgxNAbidEbHVj3RW1LsmDU0JpSBnIjZqAnaniwqYuA20XALQQcSybgtnWJb3uElK7oiT7Ui4pFjrhdwqffVc+VN+zgnyu6OHJJGUctKRvIEB/yAyAWhpe+pmKhjBtj3bIr38H6VOc/KIX1cmwG6wUg5jQ77o3EnPWAkAQThCWepyUYJUVfSQywri23KQncYq2ZgNs1SEQCbmFKwM2u3tR9X1yU9myPKhbDYNFePj5wbg2/vqOdG37XzK++PIMpNc5bU2D64MztL4OJDZ5NT1FKmLEO1o8k9uIS6Q+a50K6zpJnzK7AiBCMxAZZK8Gosx2xn4NRQ9RAd8TQHcken0gkBqxu7uOVtlAKsRH8zrbfLfhdNt3vGkgLuAVfjjGasUDFYphcclo1q9f1serVIF/75W6++z/T8Ptc0HA09ifu/AqjQejdDuWzCllcRckbYx2sH+vYS+I1ki2YgxrKsh/sEI45whFJdINZIQlGDOva+tidoie+CysYcSFihG4zn0v6XWPxBW/tiM41HFQshonLJXzx8il87MYdrN0Y4sY/tPDl90/BVTYDTvo3hDvglf+D5qeha6OKhaIMg7GOvcSvMZLWY3G8LsHrclOVpnXyIQ1DZ3v0CFy5pJ5yj/SLSl9cYPpjL9aK6Uuz3Rc19MVsw4FQzEDCRJGzXL6hBckzKhYjoL7azbc/OpVPfncn/1nVQ121m4+/oxaZcbrNsPnP0Az0bitoORWl1Bjr2Ev8GmMdf0nV9yV+Hes2AzI0V05HzBhCjmj09QtNjDdeeD2vdUiFOtRHyIJZPr72oQY8brjtP538/LY2jHFeJcoca6J3a+EKqChKWo6dUUFVtGdMW4/FIwv5bAHlEiHgDCI5rczDnEove9f4KYtlboWVl2uP+RUmMEfsX8bXrrCC8beHOvnJ39uIxcyA66lHxUJRipGB+MvYPALj1gWUdguoREq/BgXm2IPKufaDAxbGN25uJuKbYXeqG0pRJi3HzqhgrwpPyfarSKbkxUJEzhWRX7a3txesDMcdUs7/u2oaFQHhked6+Pm99sfRtHkzze3Da16nKMrEIB5/mQhWBUwAsTDG3GWM+XBNTU1By3HYvgF+8JlGGmrdPLPJjvsiwa28+9qtfP/PLSoaiqKUNCUvFsXEglk+fv756UyfbduhT/HuJBQ2/OuJLhUNRVFKGhWLPFNf4+bbn1xAd6SSgDvILYedwrzAy4TCqGgoilKyqFiMAW63UOHpAmBO+Xo+v89nAYhEUdFQFKUkUbEYB+aWvY5bBrpbxkXjrpVdfOM3ezIcqSiKUhyoWIwR31z3g/7PHleE/SpX8/XFV1Dh7gDs8MsnL7XNbhVFUYodFYsx4uHdF3Dyys08tOs8AM5s/BvHN9zPsVMexCV2/PwVq3r4w73t6opSFKXoUbEYY9Z1HQTA6dP+AcBnjrmDP14/kzOOrsAYuOPRLt5z7TZ+cVurioaiKEWLDiQ4RnxnyaUcXvd4/7bHZYXA2/I40+/z8nkPfP5YWB85niue+iN/ebCT21Z0csbRlVx0ahWzp6UZ0lJRFKUAqGUxRvyn71OESTFGvkkYV9hdzsIzruen1zRy3MFlRKJw98ou3vf17Vz3q9288HpwYHBCRVGUAqKWxRjx2U+/A3ZOgRXnQLRnaAZ3OSy7BxqXsRi4/iNTeXNHmL880MED/+3m0dW9PLq6l3kzvJx/QiWnHllBRdlgbb/i29tZMt/PZWfXDMzYpyiKMgaoZTGWNJ4Ex/0F3IHB6e6ATW9cNih5znQvn7tsCn/6xkwuO6uaumoXm7aH+cFfWrnoS1v53q0tvLy+r9/aWN8U1j4biqKMC2pZjDWhNhAPA5MqArEoPP9lqF8KZdOHHDK11sP7z63lPWfV8PgLPdzxaBcvvN7H3Su7uHtlFzOnejj9KDtYYSQKRG1Hv38/1cWBc6Zw4KFRtTQURckralmMNet/A5EeqDt4YFIkE4b2F+Hlb2Y81OsRlh1ewU1XN3LzV2dw8alVTKlxs213hFvuHjzKbryj3/Mbq9TSUBQl76hYjDXeGjj0O3DmszDt+MH73lxurYwcmDfDy0curGP5t2Zyw1VTOeWI8pT5ojGXDimiKEreKXmxKIb5LDJy4u2w36dBXFB/+OB9fc3wwpcg0p3z6dwu4Yj9y/jy+zP3/O4fUuSxLq7XIUUURRklJS8WxTKfRU4kisXMs+36lRvhkXPBxMbkkgbYsiPEjX9o5tHVPXT3js11FEWZ2GiAezxpOMa2kKpcAPtdA81PW+ti53/guc/AYd8DkeznyYDbFcPtdnHIPn5qKt288Fofu1qj/PvJbv79ZDduF+y/wM9h+wY4dF8/+83z4/Wkv6Y2z1UUBVQsxhd3AE55eGD7gibYehesvAjWfR+mnQB7vW1Ep/a4weUSDprTyRc+tD/1zoPdGMPGbWGeXhPkqZd7WbOhj5fesMvv7oGATzhwkZ9D9w1w2L4BFs724nYNiMf6pjCbt4f591NdnHl0pYqGokxSVCwKiTsAc94JB30TXvwKbPjtsMUiLhJnHVPBZWfV8OLq9f1CASAiLJjlY8EsH+86vZqunhgvvB7kuXVBVq/rY9P2MM+sDfLM2iAAlWXCkgV+DlhoFxjaPFdFQ1EmHyoWxcDCD8JL18L2+yDUCr663A6b7eWABX4uO6tmkEBkorLcxbEHl3PswbY1VUt7lNWvBVm9zgrIjuYoT68J8vSa4JBjVTQUZfKiYlEMlE2Hactg58Ow5n/h0BtzOuxXX5ox6kvX17g55YgKTjnCdvLb2RLh5fV9dtnQx/qm8JBj4qJx9+Nd/OuJLk47qoIPnFuroqEoExgVi2LhoG/CA8fa2MXCD0H1PgUpRmO9h8Z6T794nPyxN9PmjcVsn/R7n+jm4We6OfGwCvad62PxXB8LZ/vweXMP1msgXVGKGxWLYmHqMbDg/bDhZlj9OTjhn7ZvRhHT33DLQF8Y7n+6m/uftn1GXC7Yq9HLotleFs7ysdBZp3OXpQqkK4pSPKhYFBMHXQ+b/wxb74TH3g7H/RVcxTevRXJQvbLcxfqtIdZttsurm0Ns2WEf/pu3h3nomYFRd+uqXVY8ZnlZONuKSHzuDh3nSlGKFxWLYqJ8Fpx4p21K23S7jV8ceG2hS9VPskgkWgn7zbN9NuL0hWJs3BZm/dYw65tCrG8Ks2FriNaOGM92BHn2lYEAujvJgIqLRnycKw2kK0rhUbEoNqafCsf/Ax46GdZ8C+a/FyrnFbRImUQiHX6fi8Xz/CxOEBBjDDuao7zRFLICsjXMhqYQO1pSj10VjbmIxuyQJfc83sXBe/u55PRqlsz3UxYYvotO4yKKMnJULIqRxpNg3rth05/gxWvhLb8vWFFG0jw3HSLCjAYPMxo8HH/IwECIwVCMsz/VlPY4A0Rj8Ny6Pp5btxuAKTVuZk/zOIu3fz2jwZM2sK4dDBVl5KhYFCsHfQPe/Cts+iPs9xk7xHkByEfz3GwEfJmthLibamqdG49b2NkSobk9SnN7lBde7xuU1yXQOMXDXtM8zEoQkhkN9qeufUUUZWSoWBQrlfNh74/Buh/Y1lEn3TfqcaNKDTvOlXuI+ysaM+xujbJlZ5imXRG27rLrLbsi7GyOsH2PXVib/txx0bjn8S7ufaKLk5ZW8KHza2ioHd1fQl1dykRFxaKYWfIV2Ph72PEAbLkN5ry90CUaF9KNcxXH7RKmT/EwfYqHI/YffGwobNjRHGHLrjBNOyM07QqzdXeEHc0RdjQPjY1EYxBloNlvZbmw7xw/c2d4mdngobHezbR6u64qdyFZBFubACsTFRWLYibQAAd/G575KDz3KRv89k3ch0+2ca5ywecV5kz3Mmf60CbHmToYxunqMax6NciqV4cOdxLwC411Vjym1cVFxNOf1lBryzoeTYDVglHGGxWLYmfhFXZq1pZn4f6jYNGV1j3l9hW6ZHkln4H0kWCFCo45sIyl+5XR2RNj+54Iu1oi7GqNsrMlQk/QsHlHhM07IinPkWx0xEVj9YZqLv3qVpYdVs4Hz6tlWv3o/3YarFfGGxWLYsfltp3zHlwGHevguauta+r4f9i4xgRhPALpqRhOs+Cu3hi7WiLsbInadWu0X0x2tUTY0xbFpDguZoRYBB74bw8P/LcHvw9mT/UyfYq1RgYWDw019nNFWfamwRqsV8YTFYtSoHI+vPVlaLrDNqVtXQ3/Phze8meYecZAvlA7S5q/CqG7J7S7Kh+MpO9IZZmLylk+FsxKvT8aNZz2iS1Zz9MXwnZW3Dp0kMY4ZX4ZEJEaKyT11S7qq91DyjpWoqGuLiURFYtSwVsF898Ds86BJy6DbXfDirNsE9slX7TjSG29k6l9K+2ESvPfU+gSFyUjEYlccbszB7/j1z7x0DJOOrycUAT2tEXZ0xZx1lH2tNt1b59hy84IW3amdnmlon804JVd3PNEF4fv6+dty6qYP9NHXbU744yIqdBgvZJI0YmFiOwF3ALMxA5qeg/weWNMKgt/8uGrhRPvgJe/CS9dZydNan4ajvgprL/Z5tlws4pFCgoVF0nXBDgdxhi6ew274yLiCEhrR5SWjiitHTFeWt+X9viYAaLw37V9/HftQL7qChd11e5+C6Wuyk1tlYvaSruuq3JTU+WmrtJFwG+FZayD9Wq9lA5FJxZABCsOz4qID3gAuBD4R2GLVUSIy44ZteWf0Pa8tSS23gU4fu7dj8OtCW+RjafAKQ8WoqRFxXjHRbI1AU6HiFBZLlSW+5g/M3WeTC27XAIINNS4qSgTOroNrZ1ROrpjdHTH2Lw9exn8Sb3g46Lx3Ppq3vWVrRy+OMDbllUyd4aP2koX/iwdK9MxXoF6FaXRk5NYiMgi4HPA0cABwGPGmGUp8u0P/Ag4BmgDfg183RiTevCfFBhjtgPbnc8hEXkR2CvX4ycVh38PVrwVor1OQsxZhQbyuMvggK+Me9EmM/loApyP6yZeMxYzdHTHaG631klLR5S2zhhtnVHaupx1Z4y2riitnTH6wqkNeYMQiTJkNsUyv1Bb6aK2yk2Ns66ucFFd4aKmMvVnjzu19TIWoqEutdGTq2WxBDgbeApI2WZTROqAB7H9Zs8HFgLfxb7ujuhpJSJTgAuA00dy/ISn8SRYdg+sOAeiPanzxMLw+k/tevopRT9HRqlTCFdXLnEYl0uorXJTW+VmYZbzGWMI9hne+un043UlIkBvn6G3L8r2FB0f01FRltp6icdcDtnbz1uPrWSvRm+/wIzUgkk8v7rURkauYnGXMeYOABH5O9CQIs+VQBlwoTGmA3hARKqB60TkRicNEVkJzE5x/EPGmA/GN0TED/wd+L4x5pWcazTZaDwJjvsLrHwnRBM6kokHKhdA5+vw5t/sUrME9vsszL0E3IHClXkCM56urrEK1osIZYHcgvVnHVPBe86sxu930d5prZI2x+XV3h2joyvhs7Pd3h2jsztGd29q6yUec1n1ah+rXh0cmwn4ZJCVUlnuoiphqSy3+5LTExmrIfAnet+XnMTCGBPLIdtZwH1xUXBYDtwAnAjc5ZzruGwnEhE38CdgtTHmu7mUcVITarPiIC6ixotbwlYMDvgqNC6DDbfAG7+A9jXw1Pth9WdtZ7+FH4SqRQUuvDISijFYX1nmYta03M4Tixm6emNc8LmtOeX3OJcJhgzBUJRdrVEgfdPjXIgPgX/3SjsE/oGL/Jx2ZAUzGzxUVQyIT8AnWYd5iTOR+77IcBsZxS2L5JiFiOwCfmqMuS4pvRu4zhjznWFc49eAG/hAplZQIvJh4MMAjY2Nhy9fvjzXSwyiq6uLysrKER1bDBy852pqQy/Q5VnIGt97WRL6PZWR9bT5DuaFhpsAEBOmsfchZnXfRlX49f5jO717sytwEjvLTyXknlqoKqSk1L+XOKVaj+v/uqD/s9sVQwSWzGrhlIO7qSzL3d2U6zWSiV/zkHmdnLB/GxWBKKGI0Bty09PnoifkJhhyEQy56A256Q25CIbt50HpYRfhyMjdV26XIeCLUuaNEfDF8HtjBJzF74t/jvKv54b+f9yuGAIcPN/WoSpP9y2Z0fzGTjrppFXGmKXZ8uVTLMLA54wx309KbwJ+b4z5Uo7nPxZYCbyMHeMN4GZjzA8zHbd06VLz7LPP5lSHZFasWMGyZctGdGxR8MgFMO0EWPwpVjzyKMtOOB7WfR92PwYn3D44rzGw50lraWz5J0Q6nR1iYxrz3wuz3wbeND+8UDs8dTkcfcuYd/wr+e/FoVTrcfLH3kwRrH8sr3VJ1aprLNxrubQeswNHegiFDR09Mbp6YnR0Rwnn3tUlK9UVwl7TvNRWWRdaRUDsusxFZVniWgalZesjM5rfmIjkJBb5bjqbSnkkTXrqExjzuHOMkisn3j542+W2c2Ds95mheUVg6lvscuQvYNu/7SRLW++EHQ/axVMBsy+E2efB9NMGi8LWO+2Ur9rxb8Iz3q6usewwmYpc+7/0hWJ09tilq8fGWrqD8c8xunpt2l0ru7Jes6PbsGZjKGu+ZPxe6ReQijIXFQErKOUBu+0Ll7Fs2GcdHvkUi1agNkV6DbYZrVJsuAOw1wV2CbXC5r/acaf2PAGb/mAXdwDmXgr7fgLqDtGOf5OI8QrWj7dIDLf/i99nW2E11GY+byax8Ljte9pbDizjxMPLcYkkCY6huzdRfAbSunptU+a+sKGlI3X4+Pj9x77BSj7F4lVgcWKC0xu7wtk3JojIucC5ixZpoHZU+Opg74/YpfMN23pq273WlbXhZrsAiPPH0o5/Sh4YT+ulEP1f8iGExhiCIdNvwfQEY/3C0h20ghJsy62hwGjIp1jcC3xORKqMMXFH+MVAL/BIHq8zCGPMXcBdS5cuvWKsrjHpqFpkx5ta8kXY8Ad4+gNgHMdtvH9lYsc/lx8Wf3r8y6mUPONlvZSyS01EKPMLZX4XU2tT51mxIv3wL/ki1x7c5dhOeQCzgGoReYez/S9jTA/wc+CTwG0icgOwALgO+F5Sc1qllFhwGVTMTuopnkSsDx49D+qPsP0+pp9qYyKj6cuhI+gqeWSiutTGk1wti2nA35LS4tvzgU3GmFYROQX4MbZPRRtwE1YwlFKm8SQ7p0Zyxz+XD2adCz1boGUVND9ll7X/a4ViytEw9Vjb16PhLeApz/2aOoKuUmIUegKvsSbXTnmbyKGFkjFmLXDyKMukFCMJHf9w+a014fLB7AvswzzcAbtWws6HbYuqthdg1wq7rPmWzVu92PYqr5gPNftB/eFQc0DqWf80kK6UGIWawGu8KMZRZ4eFBrjHifW/gUgP1B0Mh9wAz38eWl8YeJh7q2HW2XYBCO62rap2PQY7/2MnbGp70S6JuHxQexD0boferYPTQQPpilIklLxYaIB7nPDWwKHfgcWfstZF48kDHf9SEZgKs8+3C9jOfJ2vQ/dG6FxvRaNlFXS+ZucXTyYeQE8eQXfJl/NXp3HsYKgopU7Ji4UyTgyn418qfDUwZaldEgm1W6ujZZVtqrvzP/QPtZ5MtBceu8C6rmoPHLz46oZZIbSDoaIMAxULpbD4amwAvHGZFZ6td8Nj74RY4gi6bisQwe0Q3GXdW3ueGHyeslkDwlFzANQeYGMkmYLqGhdRlJxRsVCKi1AbuDxgEkfQLbNDq89/jxWLtpcGL+1rbLyjdyts/3fCyQTKZ0H5XlC50MY/ujcO7B6PuIg2AVYmCCUvFhrgnmAkBNJflks52Nw6OJAemGYHPJx+ysAxJgZdGxLE42UrIB2vQU+TXfY8OfRaqeIiLh9MP93GVSrmgMs7uvpoE2BlglDyYqEB7glGQiC99ZFH4YSrMwfSwQbcqxbZZa+3DaRHQ9ba6H4Tut6wAfbdT8DulaQd2zIWghc+bxdxQ8Vca5VULbLr+OeKeelH5k1EXV3KBKHkxUKZYIw2kJ6I2weV8+3SeOJA+ta7U8ws6IV577KWROcb0LXeWiRdG+yy44Gh5/dWQ/lsGy+Jr9/8O3QmDIU2Xk2AtWWXMsaoWCiTj1QdDN1+Oxx74tt/NAhdGwfEo2v9wOfuN21HxPa1dklHKleXeGHqcbD7SRtTKZuRF3eXtuxSxhIVC2Xyka2DYRx3wPY0r9lv6DmMgb5m6+bq2Qq9TXbd0zTQhySdq8uE4eWv2wUAgUCjtU7KZ0GZs060Wspn2XlG0tZpHNxdGqyf1KhYKJOP4XYwTIUIBBrsUnfw0P2ZXF2eKkdkmpxWXDsg6CypOij2l7vWEZNZNpAf3D743DC27i4N1k9qSl4stDWUMmzyGRdJR4Kra6AJcApXF0AsbAUjLiDJlkrcegm3QXubbemVjAk750p0d7nB3wCv/iDBaom7vUbw1x8n60VjL8VJyYuFtoZSipJsTYATcXmhYi+7pGOQ28sRkF0rYfOtA3OMDDkmCm/+xS6JiMu6vcpmgn+qFRT/VGslJW6vvgaaE5ocj0ewXmMvRUvJi4WiFCUjaQKciVRur0UfhrkXpRg63g8HfNX2ExlknSS4vXq322U4pAvW1yyBTbfaIVd89Qnr2uFbMOPV1FjjL8NGxUJRxoLxcHVBmqHjvbZ/SLqHbb/bazv07YG+3YPXwYTt3u0QST+3NCYMr/0QXkuz31udJCB14K8f+LzhFuh4ZSC/axxiLzA+8ZcJ5lJTsVCUUibXll2J5OL2SmTLHfD4xVaI4ogX5l9m4x+hFgi1Qp+zjm+HWm3z4nAHdG/K7VqxFLEXXNZyeuoDjugkLIFpEJhuy+GrtxZYLoyHBTPBXGoqFopSyuSjZVc2Ip1WYEx4cLC+8aTMD0ETs0IRakkhJAkC07HOGY4lzWjDxGDP43bJhMtrYzFx8fA32JZn3mrYvNz24o8jzqNv18qxs2AmWO99FQtFKWXGw901nGB9IuKycQtfrZ0hMROpmhq7/HDojXYk4b4Ea6V/aRlwlfXusK3F4mOBZcNEnHV4cHrzf+GufazQ+KaAP3FpcJZpUDbdCpOncsCaeehU2PlQQvkn1gReJS8W2nRWUcaYfAfrU5Eu9uKrtxZMLkSDENw50G+lbw+EO+0S6YD2V2H7velbj4G1ojo77ThiueDy2vvjrQFczuJYSCkHqvTDnIvsEDLx40bSjLkAlEYpM6BNZxVljBln6yXn2Esy7oAN7FfMTZ8nlQXjDsBxf4MZZzqusT22mXKo2a77mm1ayFn37rSiFNwJ0R4n/57cyhjrg2c+klTuchsA99bYjpf9n2sSPlc7LrVKu/ZUgtdZeyoRE0p5uXxS8mKhKMoEYDxiL5C6s6R4BuZRCUy1S65E+yDcbls+hdvs5x0PwSvfHeziEjfUL7XCFGqzeUPt1uKJ9kBvz/CbMicwv/JdwOkjPj4XVCwURSk849XUeKTxl3S4/eCeZltlxendYdOj0YSBKstgn6uGXsMY2zS5X3Dah36Ob0e6nLydzudOCNt1WKpGd19yQMVCUZTJw3jEX4bjUhOx7iRvlR2SZYRsWbGChaMsdjZULBRFmTyMhwUzXi61cUbFQlEUJZ+Ml0ttnHEVugCKoihK8aNioSiKomSl5MVCRM4VkV+2t7cXuiiKoigTlpIXC2PMXcaYD9fUlP6ojoqiKMVKyYuFoiiKMvaoWCiKoihZEWNMocuQF0RkN7B5hIc3ADkO7lL0aF2Kj4lSD9C6FCujqctcY0zWMU4mjFiMBhF51hiztNDlyAdal+JjotQDtC7FynjURd1QiqIoSlZULBRFUZSsqFhYflnoAuQRrUvxMVHqAVqXYmXM66IxC0VRFCUralkoiqIoWVGxUBRFUbIyacVCRPYXkYdEpEdEtonI9SLiLnCZFonIL0TkBRGJisiKFHlERL4kIltEpFdEHhWRQ1Lky1q/XM81gnq8U0TuFJGtItIlIqtE5F0lWI93iMgTItIsIkERWSciXxERXynVI03dZjnfjRGRylKqj4hc7pQ7ebmylOqRcH6PiHxBRF4XkT4RaRKRm0ZShjGtjzFm0i1AHbANeBA4DbgS6Aa+WeBynQ9sAf4GvAKsSJHni0AvcBVwKvAvbGec6cOtXy7nGmE9ngRuBS4CTgb+DzDAJ0qsHh8BvgW8DTgJ+LxznR+XUj3S1O1WYIfzvVSWUn2Ay51ynwQcnbBMK6V6JJz/D045PgKcCLwH+Hax/e/z+gMslcW5Wa1AdULaNUBPYloByuVK+Px3ksQCCADtwLUJaRXA7sQfRC71y/VcI6xHQ4q0W4GNpVSPNHX7FtAGSKnWAzgeaAE+S4JYlEp9GBCLyjT7S6IezrnOBMLA/hnyFEV98vpHKpUFeBRYnpQ2x/kBnlvo8jnlSSUWJztlXJyUfjOwajj1y/VceazP54DuCVCPTzt/PinFegBu4HngUyQ9dEulPsnlTrG/JOrhnOevwH1Z8hRFfSZrzGIx8GpigjHmTexDYHFBSpQbi4Eo8HpS+isMLncu9cv1XPniLcDaYV67KOohIm4RKReR44BPAj8z9h9WUvVwuBL7dvmTFPtKrT7rRSTixJI+klS+UqnHUcBrIvJjEelwYg23icjMpHIWvD6TVSzqsK6EZFqdfcVKHdBljIkmpbcC5QmB11zql+u5Ro2InIKNx8QfUKVWj25neQx4BGslDefaRVEPEZkCfAP4tDEmnCJLqdRnO/BV4DLgXOBp4OcicnWJ1QNgOtZSOgS4BHg/cDjwTxGRYZZhTOvjyaEyExWTIk3SpBcT6cqdvC+X+uV6rhEjIvOw8Yo7jDG3jODaxVCPtwDlwJHAtcCPgY8N89rFUI9vAU8bY/6VIU/R18cYcx9wX0LSvSLiB74iIj8Y5rUL/b2Is5xvjGkGEJHt2JeSk4GHhlmGMavPZBWLVqA2RXoNqZW5WGgFqkTEnfRmUAv0JLwt5lK/XM81YkSkHrgXeBPbwiNOSdXDGPOc83GliOwBfici3y2leojIEuADwAkiEi9LebwcIhItpfqk4O/Y1nfzhnHtYqhHK7AhLhQOK4EQsD9WLIqiPpPVDfUqSf45EdkL2yrg1ZRHFAevYgOUi5LSk32VudQv13ONCBEpB+4GfMBbjTHdSeUriXqkIC4c84dx7WKox96AF9usudVZ4m7BJuBHwyhDMdQnHWYY1y6GerySJl2A2DDLMKb1maxicS9whohUJaRdjG17/EhhipQTTwAdwDvjCc5D+VxsneLkUr9czzVsRMSD7SuyN3CWMWZXKdYjDcc6643DuHYx1GMltl9C4nKDs+9s4DslVp9k3o7tK7B5GNcuhnrcDRwkIg0JaSdghf2FYZZhbOsz2qZfpbhggzzbgQewnVI+DHRR+E555cA7nOVJYE3CdrmT54vY1g0fB04B7sH+SRqHW79czjXCevwS+4b3SQZ3mjoa8JdQPf6N7YtwFnA68HXn+suHc+1C1yND/S4ndae8oq4P8A9sB8mzgHOwndoMQzt9FnU9nHNXY920T2If2JdiO+Y+MNwyjHV9xuzBV+wL1h/4MFZ1t2NbibgLXKZ5zo8+1TLPySPAl7Gug15sC51DR1K/XM81gnpsmiD1+AbwsvOHa8O6oD4BeId77ULWI0P9LmeoWBR9fYBvA+uwD7xeYBVw2UiuXQzfC9Yl9C9si7tW4Bagrtjqo0OUK4qiKFmZrDELRVEUZRioWCiKoihZUbFQFEVRsqJioSiKomRFxUJRFEXJioqFoiiKkhUVC2VEiMgtIvLNAl1bROS3ItIqIv8tRBmcclwuIisTtrtEZEGhyjNREZF3i8j9hS7HZEfFYoIgIptEZKeIVCSkfUhSzOM9ATgOO23kbGPMkakyiMgMEfmVMw9xl4hscARuzOYrMcZUGmM2jPY8uQixI5ifFJGXRaRb7LzNfxORA0d7/XySLKg55J8ndj7t/kFOjTF/MsacPjYlVHJFxWJi4QH+p9CFGC6SNKF8DswFNpnBgxMmnm8KdgyccuwUolXAYdjxcU5Lc0ypjcD8A+x3/UmgHtgHuB14awHLpExkxmooAV3Gd8EOsfEF7NzKtU7ah3CmZmVgKBFPwjErgA85ny8HHgduwg5tsQE7j8Pl2LFqdgHvSzj2FuDn2HFoOrEP4rkJ+xc7+1qwQzNclHTszxgY4uDUFPWZCdzpHP8GcIWT/kEgiJ3tqwv4eopjv4kdhM2V4X7F78cHsWPzPOqk/w3YgZ2n+FFgScIxU5wydQD/xQ6lsDJhvwEWOZ/9wP85597p3KsyZ98y7FALn3Hu63bg/c6+D2PnZA459bsrRdn3dup/ZIb61QC/x86tvBn4Svx+5PO7JsPvCtgv6btqc/a/FVjt3MctwHUJx77pnK/LWY5xypV4n98CPON8R88Ab0m69jec+nUC9+PMCY+dIfCPQLNT72cYo3G3JuKilsXE4lnsn+WzIzz+KOBF7EPxVmA5cAR27Jr3AD8WkcqE/O/G/jEbsPM6/wnAcYU94JxjGvAu4KfOnApxLsVOxlOFHRE1mT9jH6gzsQMpfltETjHG/AY7NeiTxrp9vpbi2FOBfxpjYin2JXMi9qF2hrN9L/ZhPA07FtSfEvL+BPvwm4GdG+IDGc57A/Zt/xDs/ZuFnTgpznTsA30WVrB+IiJ1xphfOte80anfuSnOfQrQZIzJFK/5kXP+BU4d34udhS1OXr7rTBhjXmHwd1Xr7Op2ylOLFY6PisgFzr4TnHWtc8yTied05ki5B/ihU/bvAfc41mScS526TsMOkR//P7zPuSd7OcdeiR0bSckBFYuJx7XAJ0Rk6giO3WiM+a2xk6L8Bfunut4Y02eMuR/7tps4Dv49xphHjTF92IHJjnHGzz8H6yb6rTEmYuzkQf/APvTj3GGMedwYEzPGBBML4ZzjOODzxpigMeZ54NfYaTRzoQFrHcTPd56ItIlIZ4pA6XXGmG5jTC+AMeZmY0ynU6frgINFpMZxlb0duNbJ/zLwu1QXd6bDvAK42hjTYozpxA5+d0lCtjD23oaNnbmuC9g3x/pNwVojKXHKejHwRacum4DvMvj+5eu7HjbGmBXGmJec7/5F7IvBiTke/lbgdWPMH5zf1p+x8zAkiupvjTGvOd/pX7GCDfaeT8Faf1FjzCpjTMdI6jAZUbGYYDgPsbuxLqnhsjPhc/zhmZyW+La5JeG6XViX0UxsTOEo5wHdJiJt2DfT6amOTcFMIP6QjbMZ+xaeC83Yt/942e503mqvxr5pJtJfDhFxi8j/E5H1ItKBde2BFZ+p2JhQYrk3p7n+VGy8ZFVC/f/tpPeX0RgTSdjuYfC9zcSg+qWgAVvPxPIl3798fdfDRkSOEpH/iMhuEWnHvuE3ZDvOYSZD73ty3XYkfE68r3/ATse63Gn4cKOIeIdfg8mJisXE5GvYN9vEP1A8GFyekJb48B4J/W+WjsuiHtiGfbA8YoypTVgqjTEfTTg203DH24D6pElc5gBbcyzXQ8AFIpLL7zuxHJcC52PdWDVYfzzYIZ13AxES6uyUKRV7sA/bJQn1rzHG5CoG2YaCfgiYLSJLM1w/jBXtxLLmev9Ske67zva7SlWXW7Gxn72MMTXYeEiuc1pvY3C9IMe6OVbc140x+2PjHudg3WFKDqhYTECMMW9gXQufTEjbjf1Dvcd5g/4AsHCUlzpbRI4TER/Wn/20MWYL1rLZR0QuExGvsxwhIvvlWP4t2NZM/ysiARE5COvXz+ond/gediKYP4jIQqeZaRUD7oh0VAF92Df3cqzrKF6mKHAbcJ2IlIvI/lgfeKryx4BfATeJyDQAEZklImekyp+CndhYQ0qMMa8DPwX+LCLLRMTn3KdLROQLTln/CnxLRKpEZC7waWxwd6Sk/K5z+F3txApbokVXhbUcgyJyJFak4+zGTiearv7/wv62LhURj4hcjJ3D4e5sFRCRk0TkQMdN14EV1GiWwxQHFYuJy/XYuXcTuQL4HPZhuAT7QB4Nt2KtmBbgcKyrCcd9dDrWR78N6xa4AdtCKFfehX2z3wb8E/iaMeaBXA40xuzBzsoXxAbPO7FB2Srgo+mP5PdYl8ZWYC3wVNL+q7AujR3YFkK/zXCuz2NbcT3luLQeJPeYxG+A/R0X1u1p8nwS+DE26N4GrAfeBtzl7P8E9q1/A/Ye3ArcnOP1U5Hyu3bI9Lt6GDvj4w4R2eOkfQy4XkQ6sTG2v8YzG2N6sA0fHnfqf3RiIYwxzViL4DPO9a4BznG+82xMB/6OFYpXsK26RiOgkwqd/EhRlIyIyC3Y1ldfKXRZlMKhloWiKIqSFRULRVEUJSvqhlIURVGyopaFoiiKkhUVC0VRFCUrKhaKoihKVlQsFEVRlKyoWCiKoihZ+f8DDwi+OpDx/QAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Import necessary functions and modules\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt\n",
    "from src.GDPolyak import run_gdpolyak_algorithm\n",
    "from src.utils import plot_gdpolyak_results\n",
    "import copy\n",
    "from AdaHD_Optimizer import AdaHD, HD\n",
    "\n",
    "# Define the quadratic sensing problem parameters\n",
    "RANK_SOLUTION = 2\n",
    "RANK_FACTORIZATION = 4\n",
    "DIMENSION = 100\n",
    "NB_MEASUREMENTS = 1000\n",
    "SEED = 3407\n",
    "\n",
    "def generate_problem_instance():\n",
    "    \"\"\"Generate the problem instance for quadratic sensing.\"\"\"\n",
    "    torch.manual_seed(SEED)\n",
    "    ground_truth = torch.randn(DIMENSION, RANK_SOLUTION, dtype=torch.double)\n",
    "    ground_truth = ground_truth / ground_truth.norm()\n",
    "    padded_ground_truth = torch.zeros(DIMENSION, RANK_FACTORIZATION, dtype=torch.double)\n",
    "    padded_ground_truth[:, :RANK_SOLUTION] = ground_truth\n",
    "    \n",
    "    x = torch.randn(RANK_FACTORIZATION * DIMENSION, dtype=torch.double)\n",
    "    x = x / torch.norm(x)\n",
    "    x.requires_grad = True\n",
    "    \n",
    "    A = torch.randn(NB_MEASUREMENTS, DIMENSION, dtype=torch.double)\n",
    "    B = torch.randn(NB_MEASUREMENTS, DIMENSION, dtype=torch.double)\n",
    "    y = torch.sum((A @ padded_ground_truth)**2, dim=1) - torch.sum((B @ padded_ground_truth)**2, dim=1)\n",
    "    \n",
    "    return padded_ground_truth, x, A, B, y\n",
    "\n",
    "def loss_function(x, A, B, y):\n",
    "    \"\"\"Compute the loss function for quadratic sensing.\"\"\"\n",
    "    x_matrix = x.view(DIMENSION, RANK_FACTORIZATION)\n",
    "    return F.mse_loss(torch.sum((A @ x_matrix)**2, dim=1) - torch.sum((B @ x_matrix)**2, dim=1), y)\n",
    "\n",
    "def procrustes_distance(x, ground_truth):\n",
    "    \"\"\"Compute the Procrustes distance between x and ground_truth.\"\"\"\n",
    "    x_matrix = x.view(DIMENSION, RANK_FACTORIZATION)\n",
    "    U1, _, V1 = torch.svd(x_matrix)\n",
    "    U2, _, V2 = torch.svd(ground_truth)\n",
    "    R = U1 @ U2.t()\n",
    "    R2 = V2 @ V1.t()\n",
    "    return torch.norm(x_matrix - R @ ground_truth @ R2, 'fro')\n",
    "\n",
    "\n",
    "ground_truth, x, A, B, y = generate_problem_instance()\n",
    "\n",
    "num_run = 10\n",
    "\n",
    "dist_run_GD = []\n",
    "dist_run_GDM = []\n",
    "dist_run_HD = []\n",
    "dist_run_AdaHD = []\n",
    "dist_run_Adam = []\n",
    "\n",
    "for ite in range(num_run):\n",
    "    \n",
    "    x_GD = copy.deepcopy(x)\n",
    "    x_GDM = copy.deepcopy(x)\n",
    "    x_HD = copy.deepcopy(x)\n",
    "    x_Adam = copy.deepcopy(x)\n",
    "    x_AdaHD = copy.deepcopy(x)\n",
    "    \n",
    "    optimizer_HD = HD([x_HD], lr=0.05, mean_duration=2, mu=0.0)\n",
    "#     optimizer_HD1\n",
    "    optimizer_GD = torch.optim.SGD([x_GD], lr=0.05, momentum=0.0, dampening=0.0, nesterov=False)\n",
    "    optimizer_GDM = torch.optim.SGD([x_GDM], lr=0.05, momentum=0.9, dampening=0.0, nesterov=False)\n",
    "\n",
    "    dist_tra_GD = []\n",
    "    dist_tra_GDM = []\n",
    "    dist_tra_HD = []\n",
    "    dist_tra_Adam = []\n",
    "    dist_tra_AdaHD = []\n",
    "    \n",
    "    max_iteration = 6000\n",
    "\n",
    "    for i in range(max_iteration):\n",
    "        \n",
    "        dist_tra_GD.append(procrustes_distance(x_GD.data, ground_truth))\n",
    "        optimizer_GD.zero_grad()\n",
    "        loss = loss_function(x_GD, A, B, y)\n",
    "        loss.backward()\n",
    "        optimizer_GD.step()\n",
    "        \n",
    "        dist_tra_GDM.append(procrustes_distance(x_GDM.data, ground_truth))\n",
    "        optimizer_GDM.zero_grad()\n",
    "        loss = loss_function(x_GDM, A, B, y)\n",
    "        loss.backward()\n",
    "        optimizer_GDM.step()\n",
    "        \n",
    "        dist_tra_HD.append(procrustes_distance(x_HD.data, ground_truth))\n",
    "        optimizer_HD.zero_grad()\n",
    "        loss = loss_function(x_HD, A, B, y)\n",
    "        loss.backward()\n",
    "        optimizer_HD.step()\n",
    "        \n",
    "#         dist_tra_Adam.append(procrustes_distance(x_Adam.data, ground_truth))\n",
    "#         optimizer_Adam.zero_grad()\n",
    "#         loss = loss_function(x_Adam, A, B, y)\n",
    "#         loss.backward()\n",
    "#         optimizer_Adam.step()\n",
    "        \n",
    "#         dist_tra_AdaHD.append(procrustes_distance(x_AdaHD.data, ground_truth))\n",
    "#         optimizer_AdaHD.zero_grad()\n",
    "#         loss = loss_function(x_AdaHD, A, B, y)\n",
    "#         loss.backward()\n",
    "#         optimizer_AdaHD.step()\n",
    "\n",
    "        \n",
    "\n",
    "    dist_tra_GD = torch.stack(dist_tra_GD)\n",
    "    dist_run_GD.append(dist_tra_GD)\n",
    "    \n",
    "    dist_tra_GDM = torch.stack(dist_tra_GDM)\n",
    "    dist_run_GDM.append(dist_tra_GDM)\n",
    "    \n",
    "    dist_tra_HD = torch.stack(dist_tra_HD)\n",
    "    dist_run_HD.append(dist_tra_HD)\n",
    "    \n",
    "#     dist_tra_Adam = torch.stack(dist_tra_Adam)\n",
    "#     dist_run_Adam.append(dist_tra_Adam)\n",
    "    \n",
    "#     dist_tra_AdaHD = torch.stack(dist_tra_AdaHD)\n",
    "#     dist_run_AdaHD.append(dist_tra_AdaHD)\n",
    "\n",
    "dist_run_GD = torch.stack(dist_run_GD, dim=0)\n",
    "dist_run_mean_GD = dist_run_GD.mean(dim=0)\n",
    "dist_run_std_GD = dist_run_GD.std(dim=0)\n",
    "\n",
    "dist_run_GDM = torch.stack(dist_run_GDM, dim=0)\n",
    "dist_run_mean_GDM = dist_run_GDM.mean(dim=0)\n",
    "dist_run_std_GDM = dist_run_GDM.std(dim=0)\n",
    "\n",
    "dist_run_HD = torch.stack(dist_run_HD, dim=0)\n",
    "dist_run_mean_HD = dist_run_HD.mean(dim=0)\n",
    "dist_run_std_HD = dist_run_HD.std(dim=0)\n",
    "\n",
    "# dist_run_Adam = torch.stack(dist_run_Adam, dim=0)\n",
    "# dist_run_mean_Adam = dist_run_Adam.mean(dim=0)\n",
    "# dist_run_std_Adam = dist_run_Adam.std(dim=0)\n",
    "\n",
    "# dist_run_AdaHD = torch.stack(dist_run_AdaHD, dim=0)\n",
    "# dist_run_mean_AdaHD = dist_run_AdaHD.mean(dim=0)\n",
    "# dist_run_std_AdaHD = dist_run_AdaHD.std(dim=0)\n",
    "\n",
    "x_axis = list(range(max_iteration))\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(x_axis, dist_run_mean_GD, '-v', linewidth=2, markevery=500, markersize=10, color = 'skyblue', label=r'GD')\n",
    "plt.plot(x_axis, dist_run_mean_GDM, '->', linewidth=2, markevery=500, markersize=10, color = 'royalblue', label=r'HB')\n",
    "plt.plot(x_axis, dist_run_mean_HD, '-*', linewidth=2, markevery=500, markersize=10, color = 'orange', label=r'HD')\n",
    "# plt.fill_between(x_axis, dist_run_mean_GD+dist_run_std_GD, dist_run_mean_GD-dist_run_std_GD, color='skyblue', alpha=0.2)\n",
    "# plt.fill_between(x_axis, dist_run_mean_GDM+dist_run_std_GDM, dist_run_mean_GDM-dist_run_std_GDM, color='royalblue', alpha=0.2)\n",
    "# plt.fill_between(x_axis, dist_run_mean_HD+dist_run_std_HD, dist_run_mean_HD-dist_run_std_HD, color='orange', alpha=0.2)\n",
    "plt.xticks(fontsize=15)\n",
    "plt.yticks(fontsize=15)\n",
    "plt.title(r'Distance to Optimal Solution', fontsize=15)\n",
    "plt.xlabel(r'Number of Gradient Computations', fontsize=12)\n",
    "# plt.ylabel(r'Distance to Optimal Solution', fontsize=15)\n",
    "plt.yscale('log')\n",
    "plt.grid(True)\n",
    "plt.legend()\n",
    "\n",
    "myname = \"matrix_sensing_algo\"\n",
    "hi = 'pictures/' + myname + \".eps\"\n",
    "plt.savefig(hi)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "pursuant-comfort",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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W29l1KhRDB8+nKrDz9PS0pgxYwZnnDGO6657kldeudw1suvmm9/g3Xf/xZw5M+uVGPGZZ55m6NChhIamEhpqoaKiMl9XeLiNiy/uZVov6z3W/7DbHeTllZGbW0pOTqnrb05OCbm5ZeZfZ5lxfPfufLZsyfZpydjtih9+2MkPP+ysVe7Y2FAPBZKQEM5vv+1n//5CVx2bzVDEP//csPGXxkIrC42mBeJNUThxPuSdx998800qKir47rvvWLVqFZ988gkbN24E4KWXXuKll16q1v6AAQN44oknOP744/nqq0+YPHkyF13UCxFh8eJFfP751HorCvBuvbjn6/JmvYAx6z4hIZyEhPCAruct/hIWZuXhh0+iV69EsrJKOHy4mMOHS1yfs7JKyMkpJTu7xKV4nFaN6fXzSkWFoZWc66Y4WbcuixNO+JDk5EiSkyNITjYyGbdqFeGyypwWTFxcKHFxYYSENP2cjRavLPQMbs3RiHM+h6+HtVNhOOdz2Gw2zj33XM4991ymTp1KRUUFS5YsYf78+cyfP59ffvnF4/zVq1dz1llneZQZGXN974Nh2QwaNIiwsDDCwsKYP38+s2fPJjk5mfHjxzN8+HB69erFsccei81m82q9OPN1Bct6ccc947Az/hISYqF9+xjGjevuVxtOqyYnp4Ts7FIPRbJ8+X7efnstFRW+E/sdOFDIgQOFPo97IyLC5lIkztiMU5HExYWRkpJLQ48y1/MsOHLG84PuS3OkJfRj3759fPXVV9x8882Nds2BAwfSuXNnOnfuTHl5OdOnT+fFF19k4sSJLF26NGgLRUFlsP7RRzNYvHh3tfjL8OEdeOihlHovdwverZfwcCszZpzDqad24NChIg4dKq7yt4jMzGI3F1qZ20CAUjPtvW8uv7wN779/WZ3k1fMsNBqN37Rt25abbrqJm266qdoxu93O999/z+TJk+nduzcrV67k2GOPJSIiwpW2xMl9991HSEgIJSUllJaW8vLLL/u85qpVq1i1apVH2RVXXMEVV1yBiNC7d2/efvtt5s+fT5cuXejWrRs9evQgNTU14El/TndXjx638PTTY6vNrP/yy++ZMOHmoCx36229FJvNQm5umcsS6NYtwe/2lFIUFZW7XGBVFUlOTikREQdrb6ieaGWh0WhqZPHixVxxxRV8/vnniAhKKddb/4IFC2o811s8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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Import necessary functions and modules\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt\n",
    "from src.GDPolyak import run_gdpolyak_algorithm\n",
    "from src.utils import plot_gdpolyak_results\n",
    "import copy\n",
    "from AdaHD_Optimizer import AdaHD, HD\n",
    "\n",
    "# Define the quadratic sensing problem parameters\n",
    "RANK_SOLUTION = 2\n",
    "RANK_FACTORIZATION = 4\n",
    "DIMENSION = 100\n",
    "NB_MEASUREMENTS = 1000\n",
    "SEED = 3407\n",
    "\n",
    "def generate_problem_instance():\n",
    "    \"\"\"Generate the problem instance for quadratic sensing.\"\"\"\n",
    "    torch.manual_seed(SEED)\n",
    "    ground_truth = torch.randn(DIMENSION, RANK_SOLUTION, dtype=torch.double)\n",
    "    ground_truth = ground_truth / ground_truth.norm()\n",
    "    padded_ground_truth = torch.zeros(DIMENSION, RANK_FACTORIZATION, dtype=torch.double)\n",
    "    padded_ground_truth[:, :RANK_SOLUTION] = ground_truth\n",
    "    \n",
    "    x = torch.randn(RANK_FACTORIZATION * DIMENSION, dtype=torch.double)\n",
    "    x = x / torch.norm(x)\n",
    "    x.requires_grad = True\n",
    "    \n",
    "    A = torch.randn(NB_MEASUREMENTS, DIMENSION, dtype=torch.double)\n",
    "    B = torch.randn(NB_MEASUREMENTS, DIMENSION, dtype=torch.double)\n",
    "    y = torch.sum((A @ padded_ground_truth)**2, dim=1) - torch.sum((B @ padded_ground_truth)**2, dim=1)\n",
    "    \n",
    "    return padded_ground_truth, x, A, B, y\n",
    "\n",
    "def loss_function(x, A, B, y):\n",
    "    \"\"\"Compute the loss function for quadratic sensing.\"\"\"\n",
    "    x_matrix = x.view(DIMENSION, RANK_FACTORIZATION)\n",
    "    return F.mse_loss(torch.sum((A @ x_matrix)**2, dim=1) - torch.sum((B @ x_matrix)**2, dim=1), y)\n",
    "\n",
    "def procrustes_distance(x, ground_truth):\n",
    "    \"\"\"Compute the Procrustes distance between x and ground_truth.\"\"\"\n",
    "    x_matrix = x.view(DIMENSION, RANK_FACTORIZATION)\n",
    "    U1, _, V1 = torch.svd(x_matrix)\n",
    "    U2, _, V2 = torch.svd(ground_truth)\n",
    "    R = U1 @ U2.t()\n",
    "    R2 = V2 @ V1.t()\n",
    "    return torch.norm(x_matrix - R @ ground_truth @ R2, 'fro')\n",
    "\n",
    "\n",
    "ground_truth, x, A, B, y = generate_problem_instance()\n",
    "\n",
    "num_run = 10\n",
    "\n",
    "dist_run_HD1 = []\n",
    "dist_run_HD2 = []\n",
    "dist_run_HD3 = []\n",
    "dist_run_HD4 = []\n",
    "\n",
    "for ite in range(num_run):\n",
    "    \n",
    "    x_HD1 = copy.deepcopy(x)\n",
    "    x_HD2 = copy.deepcopy(x)\n",
    "    x_HD3 = copy.deepcopy(x)\n",
    "    x_HD4 = copy.deepcopy(x)\n",
    "    \n",
    "    optimizer_HD1 = HD([x_HD1], lr=0.05, mean_duration=0.5, mu=0.0)\n",
    "    optimizer_HD2 = HD([x_HD2], lr=0.05, mean_duration=2, mu=0.0)\n",
    "    optimizer_HD3 = HD([x_HD3], lr=0.05, mean_duration=5, mu=0.0)\n",
    "    optimizer_HD4 = HD([x_HD4], lr=0.05, mean_duration=8, mu=0.0)\n",
    "\n",
    "    dist_tra_HD1 = []\n",
    "    dist_tra_HD2 = []\n",
    "    dist_tra_HD3 = []\n",
    "    dist_tra_HD4 = []\n",
    "    \n",
    "    max_iteration = 6000\n",
    "\n",
    "    for i in range(max_iteration):\n",
    "        \n",
    "        dist_tra_HD1.append(procrustes_distance(x_HD1.data, ground_truth))\n",
    "        optimizer_HD1.zero_grad()\n",
    "        loss = loss_function(x_HD1, A, B, y)\n",
    "        loss.backward()\n",
    "        optimizer_HD1.step()\n",
    "        \n",
    "        dist_tra_HD2.append(procrustes_distance(x_HD2.data, ground_truth))\n",
    "        optimizer_HD2.zero_grad()\n",
    "        loss = loss_function(x_HD2, A, B, y)\n",
    "        loss.backward()\n",
    "        optimizer_HD2.step()\n",
    "        \n",
    "        dist_tra_HD3.append(procrustes_distance(x_HD3.data, ground_truth))\n",
    "        optimizer_HD3.zero_grad()\n",
    "        loss = loss_function(x_HD3, A, B, y)\n",
    "        loss.backward()\n",
    "        optimizer_HD3.step()\n",
    "        \n",
    "        dist_tra_HD4.append(procrustes_distance(x_HD4.data, ground_truth))\n",
    "        optimizer_HD4.zero_grad()\n",
    "        loss = loss_function(x_HD4, A, B, y)\n",
    "        loss.backward()\n",
    "        optimizer_HD4.step()\n",
    "        \n",
    "#         dist_tra_Adam.append(procrustes_distance(x_Adam.data, ground_truth))\n",
    "#         optimizer_Adam.zero_grad()\n",
    "#         loss = loss_function(x_Adam, A, B, y)\n",
    "#         loss.backward()\n",
    "#         optimizer_Adam.step()\n",
    "        \n",
    "#         dist_tra_AdaHD.append(procrustes_distance(x_AdaHD.data, ground_truth))\n",
    "#         optimizer_AdaHD.zero_grad()\n",
    "#         loss = loss_function(x_AdaHD, A, B, y)\n",
    "#         loss.backward()\n",
    "#         optimizer_AdaHD.step()\n",
    "\n",
    "    \n",
    "    dist_tra_HD1 = torch.stack(dist_tra_HD1)\n",
    "    dist_run_HD1.append(dist_tra_HD1)\n",
    "    \n",
    "    dist_tra_HD2 = torch.stack(dist_tra_HD2)\n",
    "    dist_run_HD2.append(dist_tra_HD2)\n",
    "    \n",
    "    dist_tra_HD3 = torch.stack(dist_tra_HD3)\n",
    "    dist_run_HD3.append(dist_tra_HD3)\n",
    "    \n",
    "    dist_tra_HD4 = torch.stack(dist_tra_HD4)\n",
    "    dist_run_HD4.append(dist_tra_HD4)\n",
    "    \n",
    "#     dist_tra_Adam = torch.stack(dist_tra_Adam)\n",
    "#     dist_run_Adam.append(dist_tra_Adam)\n",
    "    \n",
    "#     dist_tra_AdaHD = torch.stack(dist_tra_AdaHD)\n",
    "#     dist_run_AdaHD.append(dist_tra_AdaHD)\n",
    "\n",
    "dist_run_HD1 = torch.stack(dist_run_HD1, dim=0)\n",
    "dist_run_mean_HD1 = dist_run_HD1.mean(dim=0)\n",
    "dist_run_std_HD1 = dist_run_HD1.std(dim=0)\n",
    "\n",
    "dist_run_HD2 = torch.stack(dist_run_HD2, dim=0)\n",
    "dist_run_mean_HD2 = dist_run_HD2.mean(dim=0)\n",
    "dist_run_std_HD2 = dist_run_HD2.std(dim=0)\n",
    "\n",
    "dist_run_HD3 = torch.stack(dist_run_HD3, dim=0)\n",
    "dist_run_mean_HD3 = dist_run_HD3.mean(dim=0)\n",
    "dist_run_std_HD3 = dist_run_HD3.std(dim=0)\n",
    "\n",
    "dist_run_HD4 = torch.stack(dist_run_HD4, dim=0)\n",
    "dist_run_mean_HD4 = dist_run_HD4.mean(dim=0)\n",
    "dist_run_std_HD4 = dist_run_HD4.std(dim=0)\n",
    "\n",
    "x_axis = list(range(max_iteration))\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(x_axis, dist_run_mean_HD1, '-v', linewidth=2, markevery=500, markersize=10, color = 'skyblue', label=r'HD-0.5')\n",
    "plt.plot(x_axis, dist_run_mean_HD2, '->', linewidth=2, markevery=500, markersize=10, color = 'royalblue', label=r'HD-2.0')\n",
    "plt.plot(x_axis, dist_run_mean_HD3, '-*', linewidth=2, markevery=500, markersize=10, color = 'darkblue', label=r'HD-5.0')\n",
    "plt.plot(x_axis, dist_run_mean_HD4, '-x', linewidth=2, markevery=500, markersize=10, color = 'black', label=r'HD-8.0')\n",
    "# plt.fill_between(x_axis, dist_run_mean_GD+dist_run_std_GD, dist_run_mean_GD-dist_run_std_GD, color='skyblue', alpha=0.2)\n",
    "# plt.fill_between(x_axis, dist_run_mean_GDM+dist_run_std_GDM, dist_run_mean_GDM-dist_run_std_GDM, color='royalblue', alpha=0.2)\n",
    "# plt.fill_between(x_axis, dist_run_mean_HD+dist_run_std_HD, dist_run_mean_HD-dist_run_std_HD, color='orange', alpha=0.2)\n",
    "plt.xticks(fontsize=15)\n",
    "plt.yticks(fontsize=15)\n",
    "plt.title(r'Distance to Optimal Solution', fontsize=15)\n",
    "plt.xlabel(r'Number of Gradient Computations', fontsize=12)\n",
    "# plt.ylabel(r'Distance to Optimal Solution', fontsize=15)\n",
    "plt.yscale('log')\n",
    "plt.grid(True)\n",
    "plt.legend()\n",
    "\n",
    "myname = \"matrix_sensing_duration\"\n",
    "hi = 'pictures/' + myname + \".eps\"\n",
    "plt.savefig(hi)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acquired-appointment",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
