{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "030528e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import numpy.matlib\n",
    "import random\n",
    "import matplotlib.pyplot as plt\n",
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7c7c9671",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams['figure.figsize'] = (8.0, 6.0)  "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5c0250ca",
   "metadata": {},
   "source": [
    "## 1. W-shape function."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "31c58f41",
   "metadata": {},
   "source": [
    "\\begin{equation*}\n",
    "w(x) = \\left\\{\n",
    "\\begin{array}{ll}\n",
    "  \\sqrt{\\epsilon}(x+(L+1)\\sqrt{\\epsilon}\\,)^2 - \\frac{1}{3}(x+(L+1)\\sqrt{\\epsilon}\\,)^3 -\\frac{1}{3}(3L+1)\\epsilon^{3/2},\n",
    "&  x \\le -L\\sqrt{\\epsilon};\\\\\n",
    "\\epsilon x + \\frac{\\epsilon^{3/2}}{3} ,&-L\\sqrt{\\epsilon} < x \\le -\\sqrt{\\epsilon};\\\\\n",
    "-\\sqrt{\\epsilon}x^2 - \\frac{x^3}{3},& -\\sqrt{\\epsilon} < x\\le 0;\\\\\n",
    "-\\sqrt{\\epsilon}x^2 + \\frac{x^3}{3},&   0<x\\le \\sqrt{\\epsilon};\\\\\n",
    "-\\epsilon x + \\frac{\\epsilon^{3/2}}{3} ,&\\sqrt{\\epsilon} < x \\le L\\sqrt{\\epsilon};\\\\\n",
    "\\sqrt{\\epsilon}(x-(L+1)\\sqrt{\\epsilon}\\,)^2 + \\frac{1}{3}(x-(L+1)\\sqrt{\\epsilon}\\,)^3 -\\frac{1}{3}(3L+1)\\epsilon^{3/2},\n",
    "& L\\sqrt{\\epsilon} < x ;\n",
    "\\end{array}\n",
    "\\right.\n",
    "\\end{equation*}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "19f4a60d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def w(x,eps = 0.01,L = 5):\n",
    "    t1 = x+(L+1)*np.sqrt(eps)\n",
    "    t2 = x-(L+1)*np.sqrt(eps)\n",
    "    if x <=  -L * np.sqrt(eps):\n",
    "        output =np.sqrt(eps) * t1**2 - 1/3 * pow(t1,3) - 1/3 * (3*L+1) * pow(eps,3/2)\n",
    "    elif x <= -np.sqrt(eps):\n",
    "        output = eps * x + pow(eps,3/2)/3\n",
    "    elif x <= 0:\n",
    "        output = - np.sqrt(eps) * x**2 - pow(x,3)/3\n",
    "    elif x<= np.sqrt(eps):\n",
    "        output = - np.sqrt(eps) * x**2 + pow(x,3)/3\n",
    "    elif x <= L * np.sqrt(eps):\n",
    "        output = -eps * x + pow(eps,3/2)/3\n",
    "    else:\n",
    "        output =np.sqrt(eps) * t2**2 + 1/3 * pow(t2,3) - 1/3 * (3*L+1) * pow(eps,3/2)\n",
    "    return output\n",
    "\n",
    "def w_array(x):\n",
    "    y = np.zeros_like(x)\n",
    "    for i in range(len(x)):\n",
    "        y[i] = w(x[i])\n",
    "    return y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4456d309",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams['figure.figsize'] = (8.0, 6.0)\n",
    "x = np.arange(-0.85,0.85,0.001)\n",
    "y = w_array(x)\n",
    "plt.grid(True)\n",
    "plt.plot(x,y)\n",
    "# plt.xlim(-0.85,0.85)\n",
    "# plt.savefig('w.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5ba68f72",
   "metadata": {},
   "source": [
    "## 2. Design the objective function."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b6c9935c",
   "metadata": {},
   "source": [
    "Consider nonconvex-strongly concave minmax optimization problem:\n",
    "$$\n",
    "\\min_{x\\in \\mathbb{R}^3}\\max_{y\\in\\mathbb{R}^2}f(x,y) = w(x_3) - 10y_1^2+x_1y_1 - 5y_2^2+x_2y_2\n",
    "$$\n",
    "then,\n",
    "$$\n",
    "\\Phi(x) = w(x_3) + \\frac{x_1^2}{40} + \\frac{x_2^2}{20} \\ .\n",
    "$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b2aeddea",
   "metadata": {},
   "outputs": [],
   "source": [
    "def f(x,y):\n",
    "    return float(w(x[2]) - y[0]**2 * 10 - 5*y[1]**2  + x[1]*y[1] + x[0]*y[0])\n",
    "\n",
    "def Phi(x):\n",
    "    return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3e4f0ca6",
   "metadata": {},
   "source": [
    "We can compute $$\\Phi(x^*) = \\Phi\\left((0,0,0.6)^T\\right) $$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "e4c8f423",
   "metadata": {},
   "outputs": [],
   "source": [
    "Phi_star = Phi(np.array([0,0,0.6]))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "46225148",
   "metadata": {},
   "source": [
    "## 3. Compute Gradient, Jecobian and Hessian."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2676680b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def dw(x,eps=0.01,L=5):\n",
    "    t1 = x+(L+1)*np.sqrt(eps)\n",
    "    t2 = x-(L+1)*np.sqrt(eps)\n",
    "    if x <=  -L * np.sqrt(eps):\n",
    "        output = 2 * np.sqrt(eps) * t1 -  pow(t1,2)\n",
    "    elif x <= -np.sqrt(eps):\n",
    "        output = eps\n",
    "    elif x <= 0:\n",
    "        output = - 2 * np.sqrt(eps) * x - pow(x,2)\n",
    "    elif x<= np.sqrt(eps):\n",
    "        output = - 2 * np.sqrt(eps) * x + pow(x,2)\n",
    "    elif x <= L * np.sqrt(eps):\n",
    "        output = -eps\n",
    "    else:\n",
    "        output = 2 * np.sqrt(eps) * t2 +  pow(t2,2)\n",
    "    return output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "5ac8fd88",
   "metadata": {},
   "outputs": [],
   "source": [
    "def d2w(x,eps=0.01,L=5):\n",
    "    t1 = x+(L+1)*np.sqrt(eps)\n",
    "    t2 = x-(L+1)*np.sqrt(eps)\n",
    "    if x <=  -L * np.sqrt(eps):\n",
    "        output = 2 * np.sqrt(eps) -  2 * t1\n",
    "    elif x <= -np.sqrt(eps):\n",
    "        output = 0\n",
    "    elif x <= 0:\n",
    "        output = - 2 * np.sqrt(eps) - 2 * x\n",
    "    elif x<= np.sqrt(eps):\n",
    "        output = - 2 * np.sqrt(eps) + 2 * x\n",
    "    elif x <= L * np.sqrt(eps):\n",
    "        output = 0\n",
    "    else:\n",
    "        output = 2 * np.sqrt(eps) +  2 * t2\n",
    "    return output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "0566ba48",
   "metadata": {},
   "outputs": [],
   "source": [
    "def df_x(x,y):\n",
    "    return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n",
    "\n",
    "def df_y(x,y):\n",
    "    return np.asmatrix([[float(x[0])-float(y[0])*20],[float(x[1])-10 * float(y[1])]])\n",
    "\n",
    "def dPhi(x):\n",
    "    return np.asmatrix([[float(x[0])/20],[float(x[1]/10)],[dw(x[2])]])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3cef139c",
   "metadata": {},
   "source": [
    "Notice that Jacobian and Hessian of $g(x,y)$ are fixed.\n",
    "$$\n",
    "\\nabla_{xy}^2 g(x,y)=\n",
    "\\begin{pmatrix}\n",
    "-1 & 0\\\\\n",
    "0 & -1\\\\\n",
    "0 & 0\n",
    "\\end{pmatrix}\n",
    "\\ \n",
    "\\text{and}\n",
    "\\ \n",
    "\\nabla_{yy}^2g(x,y)=\n",
    "\\begin{pmatrix}\n",
    "20 & 0\\\\\n",
    "0 & 10\\\\\n",
    "\\end{pmatrix}\n",
    "$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "a5ddfa8e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(matrix([[-1,  0],\n",
       "         [ 0, -1],\n",
       "         [ 0,  0]]),\n",
       " matrix([[20,  0],\n",
       "         [ 0, 10]]))"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "J_xy = np.mat('-1,0;0,-1;0,0')\n",
    "H_yy = np.mat('20,0;0,10')\n",
    "J_xy,H_yy"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1c8653c4",
   "metadata": {},
   "source": [
    "## 4. Implement some basic alogrithms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "be34670a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def AGD(h, z0, T, alpha, beta,eps=1e-10):\n",
    "    d0 = z0\n",
    "    for i in range(T):\n",
    "        grad = df_y(h,d0)\n",
    "        z1 = d0 + alpha * grad\n",
    "        d1 = z1 + beta * (z1 - z0)\n",
    "        z0,d0 = z1,d1\n",
    "        if np.sqrt(float(grad.T*grad)) < eps:\n",
    "#             print('T=',i)\n",
    "            break\n",
    "    return z1, i"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "66ed8f70",
   "metadata": {},
   "source": [
    "## 5. PRAGDA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "c2e97be3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def PRAGDA(x0,eta,theta,K,B,alpha,beta,r,T):\n",
    "    start_time = time.time()\n",
    "    running_time = [0]\n",
    "    error = []\n",
    "    oracle_calls = [0]\n",
    "    error.append(Phi(x0) - Phi_star)\n",
    "    xi = np.mat(np.random.uniform(-r,r,[3,1]))\n",
    "    x1, x0 = x0 + xi, x0 + xi\n",
    "    k,s = 0,0\n",
    "    y0, num = AGD(x0,np.mat('0;0'),T,alpha,beta)\n",
    "    calls_num = num\n",
    "    while k < K:\n",
    "        w1 = x1 + (1-theta) * (x1-x0)\n",
    "        y1, num = AGD(x1,y0, T, alpha,beta)\n",
    "        u = df_x(w1,y1)\n",
    "        x2 = w1 - eta * u\n",
    "        calls_num += (1 + num)\n",
    "        x0,x1,y0 = x1,x2,y1\n",
    "        s += (x1-x0).T * (x1-x0)\n",
    "        if (k%1==0):\n",
    "            end_time = time.time()\n",
    "            running_time.append(end_time-start_time)\n",
    "    #         print(Phi(x1)-Phi_star)\n",
    "            error.append(Phi(x1) - Phi_star)\n",
    "            oracle_calls.append(calls_num)\n",
    "#         print('k=',k)\n",
    "#         print('k*s=',k*s)\n",
    "#         print('x1 = ',x1)\n",
    "        k += 1\n",
    "        if k * s > B**2:\n",
    "#             print('---------------------------------restarted-------------------------------')\n",
    "            xi = np.mat(np.random.uniform(0,r,[3,1]))\n",
    "            x1 = x1 + xi\n",
    "            x0 = x1\n",
    "#             print('x1 = ',x1)\n",
    "            k = 0\n",
    "            s = 0\n",
    "            y0,num = AGD(x1,np.mat('0;0'),T,alpha,beta)\n",
    "            calls_num += num\n",
    "    return running_time, oracle_calls, error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "b6926c55",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\tmp\\ipykernel_29472\\871168655.py:5: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))\n",
      "D:\\tmp\\ipykernel_29472\\2650895086.py:8: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  if np.sqrt(float(grad.T*grad)) < eps:\n",
      "D:\\tmp\\ipykernel_29472\\2259515932.py:2: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n"
     ]
    }
   ],
   "source": [
    "x0 = np.mat('0.001;0.001;0.1')\n",
    "eps = 1e-8\n",
    "eta = 6.5\n",
    "theta = 0.75\n",
    "# 1/4 * eps ** (1/4)\n",
    "# chi = np.log(3/(0.05 * eps))\n",
    "K = 100\n",
    "B = 0.5\n",
    "alpha = 0.001\n",
    "beta = 0.95\n",
    "r = 0.000000001\n",
    "T = 20\n",
    "running_time1 ,oracle_calls1, error1 = PRAGDA(x0,eta,theta,K,B,alpha,beta,r,T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "b8bb31dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\tmp\\ipykernel_29472\\871168655.py:5: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))\n",
      "D:\\tmp\\ipykernel_29472\\2650895086.py:8: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  if np.sqrt(float(grad.T*grad)) < eps:\n",
      "D:\\tmp\\ipykernel_29472\\2259515932.py:2: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n"
     ]
    }
   ],
   "source": [
    "x0 = np.mat('0.001;0.001;1')\n",
    "eps = 1e-8\n",
    "eta = 6.2\n",
    "theta = 0.75\n",
    "# 1/4 * eps ** (1/4)\n",
    "# chi = np.log(3/(0.05 * eps))\n",
    "K = 100\n",
    "B = 0.5\n",
    "alpha = 0.002\n",
    "beta = 0.92\n",
    "r = 0.000000001\n",
    "T = 20\n",
    "running_time11 ,oracle_calls11, error11 = PRAGDA(x0,eta,theta,K,B,alpha,beta,r,T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "0effd928",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x2b425e631a0>]"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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VVRUZA0YMMBq3769VV5eXnMM17lhFixYYL377rvWxo0brY0bN1r33nuvFR4ebq1du9ayLK6vp61YscI644wzrPPPP9+66667avZznRvugQcesM477zxr+/btNa/S0tKaz7nGDffjjz9aHTp0sG666Sbr008/tTZv3mx98MEH1qZNm2qO4TrXRYn1ggsvvNDKzMyste+cc86x7rnnHpsSBa4jS+zBgwet1q1bW4899ljNvv3791uxsbHWc889Z1mWZe3Zs8cKDw+3Zs+eXXPM999/b4WEhFjvv/++z7IHktLSUkuStXTpUsuyuM7e0qJFC2vmzJlcXw/bu3ev1bFjRys/P9+65JJLakos19kzHnjgASs5Ofmon3GNPePPf/6zdfHFFx/zc67z0TGcwMOqqqpUWFiotLS0WvvT0tK0fPlym1IFj82bN6ukpKTW9Y2MjNQll1xSc30LCwt14MCBWsckJCQoKSmJ/w2OoaysTJLUsmVLSVxnT6uurtbs2bNVUVGhXr16cX097I477tCAAQP0m9/8ptZ+rrPnfPXVV0pISFBiYqKuueYaffPNN5K4xp6yYMECde/eXcOHD9dpp52mCy64QDNmzKj5nOt8dJRYD9u5c6eqq6sVHx9fa398fLxKSkpsShU8Dl3D413fkpISRUREqEWLFsc8BodZlqXs7GxdfPHFSkpKksR19pQ1a9bolFNOUWRkpDIzMzVv3jyde+65XF8Pmj17tlatWqWcnJw6n3GdPaNnz556+eWXlZeXpxkzZqikpEQpKSnatWsX19hDvvnmG02bNk0dO3ZUXl6eMjMzNXbsWL388suS+Gf5WMLsDhCsHA5HrfeWZdXZh5N3MteX/w2ObsyYMfriiy/00Ucf1fmM69wwnTp1UlFRkfbs2aO33npLGRkZWrp0ac3nXN+G2bJli+666y4tWrRIUVFRxzyO69ww6enpNdtdunRRr169dNZZZ+mll17Sr3/9a0lc44Y6ePCgunfvrkcffVSSdMEFF2jdunWaNm2abrzxxprjuM61cSfWw+Li4hQaGlrnv3pKS0vr/BcU3HfoidjjXd/WrVurqqpKu3fvPuYxMO68804tWLBAixcvVtu2bWv2c509IyIiQmeffba6d++unJwcJScn6+mnn+b6ekhhYaFKS0vldDoVFhamsLAwLV26VM8884zCwsJqrhPX2bOaNWumLl266KuvvuKfZQ85/fTTde6559ba17lzZxUXF0vi/5OPhRLrYREREXI6ncrPz6+1Pz8/XykpKTalCh6JiYlq3bp1retbVVWlpUuX1lxfp9Op8PDwWsds375da9eu5X+D/7EsS2PGjNHcuXP14YcfKjExsdbnXGfvsCxLlZWVXF8P6devn9asWaOioqKaV/fu3XX99derqKhIZ555JtfZCyorK7Vhwwadfvrp/LPsIRdddFGdaQ6//PJLdejQQRL/n3xMvn+WLPgdmmLrH//4h7V+/XorKyvLatasmfXtt9/aHS0g7N2711q9erW1evVqS5I1efJka/Xq1TVTlD322GNWbGysNXfuXGvNmjXWtddee9RpRtq2bWt98MEH1qpVq6y+ffsG9TQj7rrtttus2NhYa8mSJbWmzdm3b1/NMVznhhk/frxVUFBgbd682friiy+se++91woJCbEWLVpkWRbX11t+OTuBZXGdPeHuu++2lixZYn3zzTfWJ598Yg0cONCKjo6u+Xca17jhVqxYYYWFhVmPPPKI9dVXX1n//Oc/raZNm1qvvvpqzTFc57oosV7y7LPPWh06dLAiIiKsbt261UxdhBNbvHixJanOKyMjw7IsM9XIAw88YLVu3dqKjIy0+vTpY61Zs6bWd/z000/WmDFjrJYtW1pNmjSxBg4caBUXF9vw2/ino11fSdaLL75YcwzXuWF+97vf1fx/wKmnnmr169evpsBaFtfXW44ssVznhjs0H2l4eLiVkJBgXX311da6detqPucae8a///1vKykpyYqMjLTOOecca/r06bU+5zrX5bAsy7LnHjAAAABwchgTCwAAgIBDiQUAAEDAocQCAAAg4FBiAQAAEHAosQAAAAg4lFgAAAAEHEosAAAAAg4lFgAAAAGHEgsAAICAQ4kFAABAwKHEAgAAIOD8PzkkOa/fGG/MAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.semilogy(oracle_calls11,error11,'r-',label = 'PRAGDA')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "749b25a9",
   "metadata": {},
   "source": [
    "## 6. iMCN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "59f5f7b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def cubic_solver(s0,K,g,H,M,eta=0.8):\n",
    "    for i in range(K):\n",
    "        s_norm = np.sqrt(float(s0.T * s0))\n",
    "        s_grad = g + H * s0 + s_norm * s0  * M / 2\n",
    "        if np.sqrt(float(s_grad.T * s_grad)) < 1e-10:\n",
    "            break\n",
    "        s1 = s0 - eta * s_grad\n",
    "        s0 = s1\n",
    "    return s0, i"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "92b27e67",
   "metadata": {},
   "outputs": [],
   "source": [
    "def iMCN(x0,T,Kt,eps,M,alpha,beta, eta):\n",
    "    start_time = time.time()\n",
    "    running_time = [0]\n",
    "    error = []\n",
    "    oracle_calls = [0]\n",
    "    error.append(Phi(x0) - Phi_star)\n",
    "    y0 = np.mat('0;0')\n",
    "    k = 0\n",
    "    calls_num = 0\n",
    "    while k < T:\n",
    "        y1, num1 = AGD(x0,y0, Kt, alpha,beta)\n",
    "        g = df_x(x0,y1)\n",
    "        H = np.asmatrix([[0.05,0,0],[0,0.1,0],[0,0,d2w(float(x0[2]))]])\n",
    "        s0 = np.mat('0.0;0.0;0.0')\n",
    "        s1, num2 = cubic_solver(s0,Kt,g,H,M,eta)\n",
    "        x1 = x0 + s1\n",
    "        x0 = x1\n",
    "        calls_num += (num1+num2+2)\n",
    "        end_time = time.time()\n",
    "        oracle_calls.append(calls_num)\n",
    "        running_time.append(end_time-start_time)\n",
    "#         print('k=', k)\n",
    "#         print(Phi(x1)-Phi_star)\n",
    "        error.append(Phi(x1) - Phi_star)\n",
    "        k += 1\n",
    "#         print('s1=',s1)\n",
    "#         print('x0=', x0)\n",
    "        if s1.T * s1 < eps / (M * 4):\n",
    "            break\n",
    "    return running_time, oracle_calls, error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "d3ae8899",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\tmp\\ipykernel_29472\\871168655.py:5: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))\n",
      "D:\\tmp\\ipykernel_29472\\2650895086.py:8: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  if np.sqrt(float(grad.T*grad)) < eps:\n",
      "D:\\tmp\\ipykernel_29472\\2259515932.py:2: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n",
      "D:\\tmp\\ipykernel_29472\\904870526.py:13: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  H = np.asmatrix([[0.05,0,0],[0,0.1,0],[0,0,d2w(float(x0[2]))]])\n",
      "D:\\tmp\\ipykernel_29472\\1958836589.py:3: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  s_norm = np.sqrt(float(s0.T * s0))\n"
     ]
    }
   ],
   "source": [
    "x0 = np.mat('0.001;0.001;0.1')\n",
    "T = 1000\n",
    "eps = 1e-14\n",
    "Kt = 20\n",
    "M=5\n",
    "alpha = 0.001\n",
    "beta = 0.95\n",
    "eta = 2\n",
    "running_time2 ,oracle_calls2, error2 = iMCN(x0,T,Kt,eps,M,alpha,beta,eta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "1d93c256",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\tmp\\ipykernel_29472\\871168655.py:5: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))\n",
      "D:\\tmp\\ipykernel_29472\\2650895086.py:8: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  if np.sqrt(float(grad.T*grad)) < eps:\n",
      "D:\\tmp\\ipykernel_29472\\2259515932.py:2: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n",
      "D:\\tmp\\ipykernel_29472\\904870526.py:13: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  H = np.asmatrix([[0.05,0,0],[0,0.1,0],[0,0,d2w(float(x0[2]))]])\n",
      "D:\\tmp\\ipykernel_29472\\1958836589.py:3: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  s_norm = np.sqrt(float(s0.T * s0))\n"
     ]
    }
   ],
   "source": [
    "x0 = np.mat('0.001;0.001;1')\n",
    "T = 1000\n",
    "eps = 1e-14\n",
    "Kt = 20\n",
    "M=5\n",
    "alpha = 0.001\n",
    "beta = 0.95\n",
    "eta = 0.9\n",
    "running_time12 ,oracle_calls12, error12 = iMCN(x0,T,Kt,eps,M,alpha,beta,eta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "8cc1240c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x2b425e0c530>]"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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uLg4uVwu5eXlNbruOI5mz56tuLg4de7cWZdccon++c9/NnpNbW2t7rjjDsXExKhr16666qqrtG3btg78KdAWWVlZGjJkiLp166bvfe97SktL06efftroNXz/gSs3N1cDBgyo34Fp2LBheuONN+qv890Hl6ysLLlcLmVkZNSf43eg41Fi28HSpUuVkZGhmTNnqqioSCNHjlRqaqpKS0ttR8MJqqmpUWJiorKzs5u9Pm/ePM2fP1/Z2dnasGGDevXqpcsuu0xVVVX1r8nIyNCyZcu0ZMkS/f3vf1d1dbWuvPJK1dXVddSPgTZYu3atbr/9dr377rvKz8/XgQMHlJKSopqamvrX8P0Hrvj4eD3wwAPauHGjNm7cqFGjRunqq6+uLyl898Fjw4YNWrBggQYMGNDoPL8DFjjwugsvvNBJT09vdO7cc8917rnnHkuJ0B4kOcuWLat/fvDgQadXr17OAw88UH9u7969TnR0tPPEE084juM4u3fvdjp16uQsWbKk/jVff/21ExIS4rz55psdlh0nrry83JHkrF271nEcvv9g1L17d2fhwoV890GkqqrKOeuss5z8/Hzn4osvdu68807Hcfjn3xZGYr1s3759KiwsVEpKSqPzKSkpWr9+vaVU6AglJSXauXNno+8+IiJCF198cf13X1hYqP379zd6TVxcnBISEvj98DOVlZWSpB49ekji+w8mdXV1WrJkiWpqajRs2DC++yBy++23a+zYsbr00ksbned3wI4w2wECTUVFherq6hQbG9vofGxsrHbu3GkpFTrCoe+3ue/+q6++qn9NeHi4unfv3uQ1/H74D8dxlJmZqREjRighIUES338w2LRpk4YNG6a9e/fqpJNO0rJly3T++efXFxC++8C2ZMkSffDBB9qwYUOTa/zzbwcltp24XK5Gzx3HaXIOgakt3z2/H/5l6tSp+uijj/T3v/+9yTW+/8B1zjnnqLi4WLt379Zf/vIXTZo0SWvXrq2/zncfuMrKynTnnXdq1apVioyMPOrr+B3oWEwn8LKYmBiFhoY2+beq8vLyJv+GhsDSq1cvSTrmd9+rVy/t27dP33777VFfA992xx13aPny5Vq9erXi4+Prz/P9B77w8HCdeeaZGjx4sLKyspSYmKhHHnmE7z4IFBYWqry8XG63W2FhYQoLC9PatWv16KOPKiwsrP475HegY1FivSw8PFxut1v5+fmNzufn52v48OGWUqEj9OvXT7169Wr03e/bt09r166t/+7dbrc6derU6DU7duzQxx9/zO+Hj3McR1OnTtUrr7yit99+W/369Wt0ne8/+DiOo9raWr77IDB69Ght2rRJxcXF9Y/BgwfrhhtuUHFxsfr378/vgA127icLbEuWLHE6derkPPXUU87mzZudjIwMp2vXrs6XX35pOxpOUFVVlVNUVOQUFRU5kpz58+c7RUVFzldffeU4juM88MADTnR0tPPKK684mzZtcn74wx86p556quPxeOrfIz093YmPj3feeust54MPPnBGjRrlJCYmOgcOHLD1Y6EFbrvtNic6OtpZs2aNs2PHjvrHd999V/8avv/ANWPGDKegoMApKSlxPvroI+fee+91QkJCnFWrVjmOw3cfjA5fncBx+B2wgRLbTh5//HGnb9++Tnh4uDNo0KD6ZXjg31avXu1IavKYNGmS4zhmmZVf//rXTq9evZyIiAgnKSnJ2bRpU6P32LNnjzN16lSnR48eTufOnZ0rr7zSKS0ttfDToDWa+94lOX/+85/rX8P3H7huueWW+v9P79mzpzN69Oj6Aus4fPfB6MgSy+9Ax3M5juPYGQMGAAAA2oY5sQAAAPA7lFgAAAD4HUosAAAA/A4lFgAAAH6HEgsAAAC/Q4kFAACA36HEAgAAwO9QYgEAAOB3KLEAAADwO5RYAAAA+B1KLAAAAPzO/wfZ0OjwBC1SNQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.semilogy(oracle_calls12,error12,'r-',label = 'iMCN')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6230305e",
   "metadata": {},
   "source": [
    "## 7. GDA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "532f2b66",
   "metadata": {},
   "outputs": [],
   "source": [
    "def GDA(x0,T, eta1,eta2):\n",
    "    start_time = time.time()\n",
    "    running_time = [0]\n",
    "    error = []\n",
    "    oracle_calls = [0]\n",
    "    y0 = np.mat('0;0')\n",
    "    error.append(Phi(x0) - Phi_star)\n",
    "    k = 0\n",
    "    calls_num = 0\n",
    "    while k < T:\n",
    "        x1 = x0 - eta1 * df_x(x0,y0)\n",
    "        y1 = y0 + eta2 * df_y(x0,y0)\n",
    "        x0, y0 = x1,y1\n",
    "        calls_num += 2\n",
    "        if (k % 20 == 0):\n",
    "            end_time = time.time()\n",
    "            running_time.append(end_time-start_time)\n",
    "            error.append(Phi(x1) - Phi_star)\n",
    "            oracle_calls.append(calls_num)\n",
    "        k += 1\n",
    "    \n",
    "    return running_time, oracle_calls, error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "2928e417",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\tmp\\ipykernel_29472\\871168655.py:5: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))\n",
      "D:\\tmp\\ipykernel_29472\\2259515932.py:2: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n"
     ]
    }
   ],
   "source": [
    "x0 = np.mat('0.001;0.001;0.1')\n",
    "T = 601\n",
    "eta1 = 5\n",
    "eta2 = 0.005\n",
    "running_time3, oracle_calls3, error3 = GDA(x0,T,eta1,eta2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "70d16d08",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\tmp\\ipykernel_29472\\871168655.py:5: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))\n",
      "D:\\tmp\\ipykernel_29472\\2259515932.py:2: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n"
     ]
    }
   ],
   "source": [
    "x0 = np.mat('0.001;0.001;1')\n",
    "T = 601\n",
    "eta1 = 5\n",
    "eta2 = 0.005\n",
    "running_time13, oracle_calls13, error13 = GDA(x0,T,eta1,eta2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "126c924b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x2b4269f1880>]"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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y+uxmuO9e/dq9uzZyszMVGZmpmbPnq19+/b18qeLX0eb946ODn3nO9/RmDFjlJaWJrfbrRtuuEGBQKDLOeJ23k3E3HPPPWcmJSWZv/jFL8wdO3aYd999t5mWlmZ+/PHHVkdLSJdeeqn59NNPm9u3bzfLy8vNz3/+8+awYcPM5ubmyDE/+clPzPT0dPMPf/iDuW3bNvO6664zCwoKzKampsgxc+fONT0ej1laWmq+8cYb5vTp081x48aZnZ2dVnyshLJp0ybzlFNOMceOHWvefffdkXHmPfYaGhrM4cOHmzfeeKO5ceNGc/fu3ebf/vY3c9euXZFjmPfY+tGPfmRmZ2ebL730krl7927z+eefNwcNGmQuXrw4cgxzfvJWr15t3n///eYf/vAHU5L54osvdnk9VnN82WWXmUVFReb69evN9evXm0VFReYVV1zRVx8z7hxt3vft22decskl5sqVK813333XfP31180pU6aYxcXFXc4Rr/NOie0FZ599tjl37twuY2eeeab53e9+16JE/Uttba0pyfznP/9pmqZphsNhMz8/3/zJT34SOaatrc3MzMw0n3jiCdM0D/6LmpSUZD733HORY/x+v2mz2cy//vWvffsBEsz+/fvNz3zmM2Zpaal54YUXRkos8947vvOd75jnn3/+EV9n3mPv85//vHnzzTd3GfvCF75gXn/99aZpMue94dNlKlZzvGPHDlOSuWHDhsgxr7/+uinJfPfdd3v5U8W/aH95+LRNmzaZkiIX3uJ53llOEGPt7e0qKytTSUlJl/GSkhKtX7/eolT9S2NjoyQpKytLkrR7925VV1d3mXOXy6ULL7wwMudlZWXq6Ojocozb7VZRURG/l2O444479PnPf16XXHJJl3HmvXf86U9/0qRJk3TttdcqNzdXEyZM0C9+8YvI68x77J1//vn6+9//rvfff1+S9Oabb+q1117T5ZdfLok57wuxmuPXX39dmZmZmjJlSuSYc845R5mZmfwejlNjY6MMw9DgwYMlxfe8O3rtzANUXV2dQqGQ8vLyuozn5eWpurraolT9h2maWrBggc4//3wVFRVJUmReo835xx9/HDnG6XRqyJAh3Y7h93Jkzz33nN544w1t3ry522vMe+/48MMPtWzZMi1YsED/+Z//qU2bNumuu+6Sy+XSDTfcwLz3gu985ztqbGzUmWeeKbvdrlAopAcffFBf/vKXJfHPel+I1RxXV1crNze32/lzc3P5PRyHtrY2ffe739VXvvIVZWRkSIrveafE9hLDMLp8b5pmtzH03Lx58/TWW2/ptdde6/baicw5v5cjq6ys1N13361XXnlFycnJRzyOeY+tcDisSZMm6cc//rEkacKECXr77be1bNky3XDDDZHjmPfYWblypZ599ln99re/1VlnnaXy8nLNnz9fbrdbc+bMiRzHnPe+WMxxtOP5PRxbR0eHvvSlLykcDmvp0qXHPD4e5p3lBDGWk5Mju93e7W8etbW13f6GiZ6588479ac//UmvvvqqvF5vZDw/P1+Sjjrn+fn5am9v1969e494DLoqKytTbW2tiouL5XA45HA49M9//lM///nP5XA4IvPGvMdWQUGBRo8e3WVs1KhRqqiokMQ/773hW9/6lr773e/qS1/6ksaMGaPZs2frnnvu0cKFCyUx530hVnOcn5+vmpqabuffs2cPv4ej6Ojo0Be/+EXt3r1bpaWlkauwUnzPOyU2xpxOp4qLi1VaWtplvLS0VOeee65FqRKbaZqaN2+eXnjhBf3jH//QiBEjurw+YsQI5efnd5nz9vZ2/fOf/4zMeXFxsZKSkrocU1VVpe3bt/N7OYLPfvaz2rZtm8rLyyNfkyZN0le/+lWVl5fr1FNPZd57wXnnnddtC7n3339fw4cPl8Q/772htbVVNlvXPw7tdntkiy3mvPfFao6nTp2qxsZGbdq0KXLMxo0b1djYyO/hCA4X2J07d+pvf/ubsrOzu7we1/Pea7eMDWCHt9j65S9/ae7YscOcP3++mZaWZn700UdWR0tI3/jGN8zMzExzzZo1ZlVVVeSrtbU1csxPfvITMzMz03zhhRfMbdu2mV/+8pejbs3i9XrNv/3tb+Ybb7xhXnzxxWx/00P/vjuBaTLvvWHTpk2mw+EwH3zwQXPnzp3mb37zGzM1NdV89tlnI8cw77E1Z84c0+PxRLbYeuGFF8ycnBzz29/+duQY5vzk7d+/39y6dau5detWU5L5yCOPmFu3bo3cBR+rOb7sssvMsWPHmq+//rr5+uuvm2PGjBnQW2wdbd47OjrMK6+80vR6vWZ5eXmXP2ODwWDkHPE675TYXvL444+bw4cPN51Opzlx4sTIdlDoOUlRv55++unIMeFw2Pz+979v5ufnmy6Xy5w2bZq5bdu2Luc5cOCAOW/ePDMrK8tMSUkxr7jiCrOioqKPP01i+3SJZd57x5///GezqKjIdLlc5plnnmkuX768y+vMe2w1NTWZd999tzls2DAzOTnZPPXUU83777+/yx/izPnJe/XVV6P+t3zOnDmmacZujuvr682vfvWrZnp6upmenm5+9atfNffu3dtHnzL+HG3ed+/efcQ/Y1999dXIOeJ13g3TNM3eu84LAAAAxB5rYgEAAJBwKLEAAABIOJRYAAAAJBxKLAAAABIOJRYAAAAJhxILAACAhEOJBQAAQMKhxAIAACDhUGIBAACQcCixAAAASDiUWAAAACSc/w+nHX+2xF02BwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.semilogy(oracle_calls3,error3,'y-',label = 'GDA')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4c80343e-2504-46a1-9d50-f752b5a83034",
   "metadata": {},
   "source": [
    "## 8.MCN "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "f3613010-403d-4cc6-aa21-27c63d84ffab",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy.linalg\n",
    "\n",
    "def cubic_newton_step(Kt, g, H, M, eps1):\n",
    "    \n",
    "    n = g.shape[0] \n",
    "    num2 = 0        \n",
    "    eps = eps1      \n",
    "    max_iters = Kt\n",
    "\n",
    "    def f(T, T_norm):\n",
    "        return g.dot(T) + 0.5 * H.dot(T).dot(T) + (M / 6) * T_norm**3\n",
    "\n",
    "    def h(r, der=False):\n",
    "        A = H + M * r * np.eye(n)\n",
    "        eigenvalues = np.linalg.eigvalsh(A)\n",
    "        is_positive_definite = np.all(eigenvalues > 0)\n",
    "\n",
    "        if is_positive_definite:\n",
    "            try:\n",
    "                ArB_cho_factor = scipy.linalg.cho_factor(A, lower=False)\n",
    "                T = scipy.linalg.cho_solve(ArB_cho_factor, -g)\n",
    "                T_norm = np.linalg.norm(T)\n",
    "                h_r = r - T_norm\n",
    "                if der:\n",
    "                    BT = np.eye(n).dot(T)  \n",
    "                    h_r_prime = 1 + M / T_norm * \\\n",
    "                                scipy.linalg.cho_solve(ArB_cho_factor, BT).T.dot(BT)\n",
    "                else:\n",
    "                    h_r_prime = None\n",
    "            except np.linalg.LinAlgError:\n",
    "                is_positive_definite = False\n",
    "        else:\n",
    "            U, S, Vt = np.linalg.svd(A)\n",
    "            S_inv = np.diag(1 / (S + 1e-8))  \n",
    "            A_inv = Vt.T @ S_inv @ U.T\n",
    "            T = -A_inv @ g\n",
    "            T_norm = np.linalg.norm(T)\n",
    "            h_r = r - T_norm\n",
    "            if der:\n",
    "                BT = np.eye(n).dot(T)  \n",
    "                h_r_prime = 1 + M / (T_norm + 1e-8) * ((A_inv @ BT).T @ BT)[0, 0]\n",
    "            else:\n",
    "                h_r_prime = None\n",
    "\n",
    "        return h_r, T, h_r_prime\n",
    "\n",
    "    try:\n",
    "        max_r = 1  \n",
    "        for i in range(max_iters):\n",
    "            h_r, T, _ = h(max_r)\n",
    "            num2 += 1  \n",
    "            if h_r < -eps:\n",
    "                max_r *= 2  \n",
    "            elif -eps <= h_r <= eps:\n",
    "                break       \n",
    "            else:\n",
    "                break      \n",
    "\n",
    "        r = max_r\n",
    "        for i in range(max_iters):\n",
    "            h_r, T, h_r_prime = h(r, der=True)\n",
    "            num2 += 1  \n",
    "            if -eps <= h_r <= eps:\n",
    "                break       \n",
    "            r -= h_r / h_r_prime  \n",
    "\n",
    "        s = T  \n",
    "    except (np.linalg.LinAlgError, ValueError) as e:\n",
    "        s = np.zeros_like(g) \n",
    "        print(f\"error: {e}\")  \n",
    "    return s, num2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "da674198-d38b-4f75-bbdd-e7f6bce6e826",
   "metadata": {},
   "outputs": [],
   "source": [
    "def MCN(x0,T,Kt,eps,M,alpha,beta,eps1):\n",
    "    start_time = time.time()\n",
    "    running_time = [0]\n",
    "    error = []\n",
    "    oracle_calls = [0]\n",
    "    error.append(Phi(x0) - Phi_star)\n",
    "    y0 = np.mat('0;0')\n",
    "    k = 0\n",
    "    calls_num = 0\n",
    "    while k < T:\n",
    "        y1, num1 = AGD(x0,y0, Kt, alpha,beta)\n",
    "        g = df_x(x0,y1)\n",
    "        H = np.asmatrix([[0.05,0,0],[0,0.1,0],[0,0,d2w(float(x0[2]))]])\n",
    "        s1, num2 = cubic_newton_step(Kt,g,H,M,eps1)\n",
    "        x1 = x0 + s1\n",
    "        x0 = x1\n",
    "        calls_num += (num1+num2+2)\n",
    "        end_time = time.time()\n",
    "        oracle_calls.append(calls_num)\n",
    "        running_time.append(end_time-start_time)\n",
    "        error.append(Phi(x1) - Phi_star)\n",
    "        k += 1\n",
    "\n",
    "        s1_norm_sq = np.linalg.norm(s1) ** 2  \n",
    "        if s1_norm_sq < eps / (M * 4):\n",
    "            break\n",
    "    return running_time, oracle_calls, error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "3749a4be-571b-4d84-8bd0-87cf3fdaf275",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\tmp\\ipykernel_29472\\871168655.py:5: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))\n",
      "D:\\tmp\\ipykernel_29472\\2650895086.py:8: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  if np.sqrt(float(grad.T*grad)) < eps:\n",
      "D:\\tmp\\ipykernel_29472\\2259515932.py:2: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n",
      "D:\\tmp\\ipykernel_29472\\3377986987.py:13: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  H = np.asmatrix([[0.05,0,0],[0,0.1,0],[0,0,d2w(float(x0[2]))]])\n"
     ]
    }
   ],
   "source": [
    "x0 = np.mat('0.001;0.001;0.1')\n",
    "T = 1000\n",
    "eps = 1e-14\n",
    "Kt = 20\n",
    "M=5\n",
    "alpha = 0.001\n",
    "beta = 0.95\n",
    "eps1 = 1e-8\n",
    "running_time4 ,oracle_calls4, error4 = MCN(x0,T,Kt,eps,M,alpha,beta,eps1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "cc998d24-d12e-4853-b634-b56b3af16a08",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\tmp\\ipykernel_29472\\871168655.py:5: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))\n",
      "D:\\tmp\\ipykernel_29472\\2650895086.py:8: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  if np.sqrt(float(grad.T*grad)) < eps:\n",
      "D:\\tmp\\ipykernel_29472\\2259515932.py:2: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n",
      "D:\\tmp\\ipykernel_29472\\3377986987.py:13: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  H = np.asmatrix([[0.05,0,0],[0,0.1,0],[0,0,d2w(float(x0[2]))]])\n"
     ]
    }
   ],
   "source": [
    "x0 = np.mat('0.001;0.001;1')\n",
    "T = 1000\n",
    "eps = 1e-14\n",
    "Kt = 20\n",
    "M=5\n",
    "alpha = 0.001\n",
    "beta = 0.95\n",
    "eps1 = 1e-8\n",
    "running_time14 ,oracle_calls14, error14 = MCN(x0,T,Kt,eps,M,alpha,beta,eps1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a2a8aff0-fb41-44bf-95aa-66c7b1091f32",
   "metadata": {},
   "source": [
    "##  9.LMCN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "87ac0d04-25c7-4455-b0c9-18e308146c18",
   "metadata": {},
   "outputs": [],
   "source": [
    "def LMCN(x0,T,Kt,eps,M,alpha,beta,eps1,m):\n",
    "    start_time = time.time()\n",
    "    running_time = [0]\n",
    "    error = []\n",
    "    oracle_calls = [0]\n",
    "    error.append(Phi(x0) - Phi_star)\n",
    "    y0 = np.mat('0;0')\n",
    "    k = 0\n",
    "    calls_num = 0\n",
    "    while k < T:\n",
    "        y1, num1 = AGD(x0,y0, Kt, alpha,beta)\n",
    "        g = df_x(x0,y1)\n",
    "        if k % m == 0:\n",
    "            H = np.asmatrix([[0.05, 0, 0],\n",
    "                             [0, 0.1, 0],\n",
    "                             [0, 0, d2w(float(x0[2]))]])\n",
    "            calls_num +=1\n",
    "            \n",
    "        s1, num2 = cubic_newton_step(Kt,g,H,M,eps1)\n",
    "        x1 = x0 + s1\n",
    "        x0 = x1\n",
    "        calls_num += (num1+num2+1)\n",
    "        end_time = time.time()\n",
    "        oracle_calls.append(calls_num)\n",
    "        running_time.append(end_time-start_time)\n",
    "        error.append(Phi(x1) - Phi_star)\n",
    "        k += 1\n",
    "\n",
    "        #s1_norm_sq = np.linalg.norm(s1) ** 2\n",
    "        #if s1_norm_sq < eps / (M * 4):\n",
    "            #break\n",
    "    return running_time, oracle_calls, error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "e9f86e77-0dc5-40ca-b694-67cba2729917",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\tmp\\ipykernel_29472\\871168655.py:5: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))\n",
      "D:\\tmp\\ipykernel_29472\\2650895086.py:8: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  if np.sqrt(float(grad.T*grad)) < eps:\n",
      "D:\\tmp\\ipykernel_29472\\2259515932.py:2: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n",
      "D:\\tmp\\ipykernel_29472\\682651226.py:16: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  [0, 0, d2w(float(x0[2]))]])\n"
     ]
    }
   ],
   "source": [
    "x0 = np.mat('0.001;0.001;0.1')\n",
    "T = 1000\n",
    "eps = 1e-14\n",
    "Kt = 20\n",
    "M=5\n",
    "alpha = 0.003\n",
    "beta = 0.9\n",
    "eps1 = 1e-8\n",
    "m=3\n",
    "running_time5 ,oracle_calls5, error5 = LMCN(x0,T,Kt,eps,M,alpha,beta,eps1,m)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "27608ba0-cfa8-46b2-a505-f420606edbd3",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\tmp\\ipykernel_29472\\871168655.py:5: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return float(x[0]**2 / 40 + x[1]**2/20 + w(x[2]))\n",
      "D:\\tmp\\ipykernel_29472\\2650895086.py:8: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  if np.sqrt(float(grad.T*grad)) < eps:\n",
      "D:\\tmp\\ipykernel_29472\\2259515932.py:2: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  return np.asmatrix([[float(y[0])],[float(y[1])],[dw(float(x[2]))]])  # x and y are np.matrix type.\n",
      "D:\\tmp\\ipykernel_29472\\682651226.py:16: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  [0, 0, d2w(float(x0[2]))]])\n"
     ]
    }
   ],
   "source": [
    "x0 = np.mat('0.001;0.001;1')\n",
    "T = 1000\n",
    "eps = 1e-14\n",
    "Kt = 20\n",
    "M=5\n",
    "alpha = 0.001\n",
    "beta = 0.95\n",
    "eps1 = 1e-8\n",
    "m=3\n",
    "running_time15 ,oracle_calls15, error15 = LMCN(x0,T,Kt,eps,M,alpha,beta,eps1,m)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8cd855d5",
   "metadata": {},
   "source": [
    "## 10. Results comparition"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "c5c13ca3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Me6//35j48aNRnx8vPH9998b+/fvL2mjuak/f/zjH43AwEDj22+/NeLj442vvvrK8Pb2NqZNm1bSRvNTN5YuXWq88sorxsKFCw3AWLx4can6mpqH66+/3ujSpYuxbt06Y926dUaXLl2MESNG1NVtNliVzc+JEyeMa6+91pg3b57xyy+/GOvXrzeuvPJKIyoqqlQfdTU/CrhryBVXXGFMmDChVFmnTp2MF198sZ5G1DQlJycbgLF69WrDMAyjqKjIaNmypfHWW2+VtMnNzTX8/PyM999/3zAM80Npt9uNuXPnlrRJTEw0XFxcjP/+9791ewONUFZWltGxY0djxYoVxsCBA0sCbs1N/XnhhReM/v37V1ivualfN954o/Hggw+WKouOjjbuuecewzA0P/Xl3ICupuZh165dBmBs2LChpM369esNwPjll19q+a4aj/L+Q3SuTZs2GUDJYmhdzo+2lNSA/Px8YmNjGTZsWKnyYcOGsW7dunoaVdOUkZEBQEBAAADx8fEcPXq01Ny4ubkxcODAkrmJjY3F4XCUahMaGkqXLl00fzXgscce48Ybb+Taa68tVa65qT/ffPMNvXr14rbbbiM4OJgePXowa9asknrNTf3q378/P/zwA3v37gVg+/btrF27lhtuuAHQ/DiLmpqH9evX4+fnx5VXXlnS5qqrrsLPz09zVcMyMjKwWCw0a9YMqNv5sdXMLTRtqampFBYW0qJFi1LlLVq04OjRo/U0qqbHMAyefvpp+vfvT5cuXQBK/v7Lm5uEhISSNq6urvj7+5dpo/m7OHPnzmXr1q1s3ry5TJ3mpv789ttvzJw5k6effpqXX36ZTZs28eSTT+Lm5sZ9992nualnL7zwAhkZGXTq1Amr1UphYSF/+tOfuPPOOwF9dpxFTc3D0aNHCQ4OLtN/cHCw5qoG5ebm8uKLL3LXXXfh6+sL1O38KOCuQRaLpdRrwzDKlEntefzxx9mxYwdr164tU1edudH8XZxDhw4xceJEli9fjru7e4XtNDd1r6ioiF69evHmm28C0KNHD3bu3MnMmTO57777StppburHvHnzmDNnDl988QWdO3cmLi6OSZMmERoaytixY0vaaX6cQ03MQ3ntNVc1x+FwMGbMGIqKipgxY8Z529fG/GhLSQ0ICgrCarWW+Z9OcnJymf/5Su144okn+Oabb1i5ciVh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GDGCSy65BH9//3JXywMCApg/fz4+Pj488cQTdOzYkTvuuIORI0fSrl07rr766pJV5Mp8/vnndOvWjWnTptGmTRuGDBnCmDFjGDBgAC1btuS6664r9R+Lytx33308/vjjHDp0iO7du3P11Vdz1113MWjQIEJDQ5k8eXJJ2yeffBIvLy9mzJhBly5duPPOO7n66qsZOHBghf/JuBAJCQnceuutNG/enGuvvZZ77rmHESNGEBERwW+//caoUaP04KRIE6SAW0Qavfj4eA4dOlQquF6zZg3ARQXcAEOGDGHz5s3ceeedHD58mAULFnD06NGSlIA1sZ2k2Msvv8y3337LwIED2bx5M4sWLcLNzY3nn3+ejRs3lnvKZGVcXV2JiYnhkUcewd3dnW+//Zbdu3fzxBNPsGLFijIPlxYbPHgwcXFxPPTQQxQUFLBkyRI2bNhAcHAwU6ZMoWXLlue9dosWLdiwYQNTp06lY8eObN68mSVLlnD48GF69OjBP/7xjwvKHvPuu++yePFihgwZws8//8zChQuJj49nyJAhpTKhXHLJJWzevJmRI0eSmprKN998Q3Z2Nh988EGNrHBfddVV/PGPfyQqKoo9e/bw1VdfsWXLFrp168ann35aa9tWRMS5WYyLfRxbREREREQqpBVuEREREZFapIBbRERERKQWKeAWEREREalFCrhFRERERGqRAm4RERERkVqkgFtEREREpBYp4BYRERERqUUKuEVEREREapECbhERERGRWqSAW0RERESkFingFhERERGpRQq4RURERERqkQJuEREREZFa9P/FSBBUN3Is5AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams['figure.figsize'] = (8.0, 6.0)\n",
    "plt.semilogy(oracle_calls1,error1,'r-o',label = 'PRAGDA')\n",
    "plt.semilogy(oracle_calls2,error2,'b-d',label = 'iMCN')\n",
    "plt.semilogy(oracle_calls3,error3,'y-s',label = 'GDA')\n",
    "plt.semilogy(oracle_calls4,error4,'g--*',label = 'MCN') \n",
    "plt.semilogy(oracle_calls5,error5,'m-.^',label = 'LMCN')  \n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.xlabel('# of oracle calls',fontsize = 15)\n",
    "plt.xlim(0, 1200)\n",
    "plt.ylabel('log of error',fontsize = 15)\n",
    "plt.savefig('pragda2.pdf')\n",
    "plt.show(block=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "8752f8f2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtwAAAITCAYAAAA0F8sIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAADh0ElEQVR4nOzdd3gU1frA8e/spmx6ISQkJCGhd9AAIk1QAQGliyIiiqiIBUQvih29il79ecUColJULKCAlStFOkgLBJBeEgIkIZ3UTTa78/tj2EBI22w6vJ/n2Wd3Z87MnHUSfHP2Pe9RVFVVEUIIIYQQQlQLXW13QAghhBBCiGuZBNxCCCGEEEJUIwm4hRBCCCGEqEYScAshhBBCCFGNJOAWQgghhBCiGknALYQQQgghRDWSgFsIIYQQQohqJAG3EEIIIYQQ1cihtjtwrbFYLMTFxeHh4YGiKLXdHSGEEEIIcRVVVcnMzCQoKAidrvrHnyXgrmJxcXGEhITUdjeEEEIIIUQ5zp49S3BwcLVfRwLuKubh4QFAdHQ0vr6+tdwbcSWTycSaNWsYMGAAjo6Otd0dcQW5N3Wb3J+6S+5N3SX3pm5LTU0lPDy8MG6rbhJwVzFrGomHhweenp613BtxJZPJhKurK56envKPXx0j96Zuk/tTd8m9qbvk3tRtJpMJoMbSf2XSpBBCCCGEENVIAu4SjBgxAh8fH0aPHl3bXRFCCCGEEPWcBNwlePrpp/n6669ruxtCCCGEEOIaIDncJejXrx8bN26s7W4IIYQQog5SVZWCggLMZnOpbUwmEw4ODhiNxjLbieqh1+txcHCoMyWa613AvXnzZt577z0iIyOJj49n5cqVDB8+vEibuXPn8t577xEfH0+7du348MMP6d27d+10WAghhBDXjPz8fOLj48nJySmznaqqNGrUiLNnz9aZoO964+rqSmBgIE5OTrXdlfoXcGdnZ9OpUyceeughRo0aVWz/0qVLmTZtGnPnzqVnz57Mnz+fQYMGcfjwYUJDQwGIiIggLy+v2LFr1qwhKCio2j+DEEIIIeofi8VCdHQ0er2eoKAgnJycSg2mLRYLWVlZuLu718jCKuIyVVXJz88nKSmJ6OhoWrRoUev3oN4F3IMGDWLQoEGl7v/ggw94+OGHmTRpEgAffvghq1evZt68ecyePRuAyMjIKutPXl5ekeA9IyMD0L5KspacEXWD9X7Ifal75N7UbXJ/6i65NzUrLy8Ps9lM48aNcXV1LbOtNehzdnaWEe5a4OzsjF6vJzY2lpycHJydnYvsr+nfmXoXcJclPz+fyMhIXnjhhSLbBwwYwPbt26vlmrNnz2bWrFnFtm/YsKHcX0ZRO9auXVvbXRClkHtTt8n9qbvk3tQMBwcHGjVqRE5ODgUFBTYdk5mZWc29EqXJz88nNzeXTZs2Fbtf5aUEVbVrKuBOTk7GbDYTEBBQZHtAQAAJCQk2n2fgwIHs3buX7OxsgoODWblyJV27di2x7cyZM5k+fXrh+4yMDEJCQujXrx8NGjSw74OIamEymVi7di39+/eXRQjqGLk3dZvcn7pL7k3NMhqNnD17Fnd3dwwGQ5ltVVUlMzMTDw8PGeGuJUajERcXF/r06VPsfqWkpNRoX66pgNvq6h9sVVUr9MO+evVqm9s6OzsX+5oCwNHRUf7xq6Pk3tRdcm/qNrk/dZfcm5phNptRFAWdTlduTrDFYgEobC9qnk6nQ1GUEn8/avr35ZoKuP38/NDr9cVGsxMTE4uNegshhBBC1BqzGbZsgfh4CAyE3r1Br6/tXolqck39yeXk5ERERESxXLa1a9fSo0ePWuqVEEIIIcQVVqyAsDDo1w/uu097DgvTtleTBx98EEVRCkd8mzZtynPPPUd2djYxMTGF+xRFwcvLi+7du/Pbb7+VeK63334bvV7PO++8U+L+hIQEpk6dSvPmzTEYDAQEBNCrVy8+++yzIrnTYWFhhdd0cXEhLCyMMWPGsH79+hLPm5ubi4+PD76+vuTm5lb+P0oNqncBd1ZWFlFRUURFRQEQHR1NVFQUsbGxAEyfPp0vv/yShQsXcuTIEZ555hliY2OZPHlyjfbz558lX0sIIYQQV1mxAkaPhnPnim4/f17bXo1B9x133EF8fDynT5/m3//+N3PnzuW5554r3L9u3Tri4+PZuXMn3bp1Y9SoUfzzzz/FzrNo0SJmzJjBwoULi+07ffo0N9xwA2vWrOHtt99m3759rFu3jmeeeYbffvuNdevWFWn/xhtvEB8fz7Fjx/j666/x9vbm9ttv56233ip27uXLl9O+fXvatm3Limr871Qd6l1KyZ49e+jXr1/he+uExQkTJrB48WLuueceUlJSCm9g+/btWbVqFU2aNKnRfn78YRS33+qBr58eR0c/DIbQGr2+EEIIIWqAqkJJFS8sFsjO1tJErDncZjM8/bR2TEnnURSYOhVuv7389BJXV619BTg7O9OoUSMA7rvvPjZs2MDPP//M888/D0CDBg1o1KgRjRo14q233uLjjz9mw4YNtG/fvvAcmzZtIjc3lzfeeIOvv/6azZs306dPn8L9U6ZMwcHBgT179uDm5la4vUOHDowaNQr1qs/u4eFR2KfQ0FD69OlDYGAgr776KqNHj6ZVq1aFbRcsWMD999+PqqosWLCAcePGVejz16Z6F3D37du32M262pQpU5gyZUoN9aiUPgydTvSZ/USfAZ3OQLduxyToFkIIIa41OTng7l5ssw7wrui5VFUb+fbyKr9tVhZcEdDaw8XFpcR61CaTiS+++AIoPrlwwYIFjB07FkdHR8aOHcuCBQsKA+6UlJTCkW23UvpmSxGLqVOn8uabb/LLL78wY8YMAE6dOsXff//NihUrUFWVadOmcfr0aZo2bVqhz1xb6l1KSX3huGQCXPq7wGIxYjIl126HhBBCCCEu2bVrF9999x233XZb4bYePXoUljx89tlnC3OqrTIyMli+fDn3338/APfffz8//fRT4aJ/J0+eRFXVIqPSoBW1cHd3x93dvXA0vSy+vr74+/sTExNTuG3hwoUMGjSoMIf7jjvuKDGlpa6SgLua+Me25NzmrhzLhAQjYDHXdpeEEEIIUdVcXbXR5qselowM0s+dw5KRcXn7qlW2nXPVqhLPWeRhx+J6v//+e2FAffPNN9OnTx8+/vjjwv1Lly5l3759/PrrrzRv3pwvv/wSX1/fwv3fffcdTZs2pVOnTgB07tyZpk2b8sMPPxS5ztWj2Lt27SIqKop27doVWZ27LFeWdDabzXz11VeFgT5owf5XX32F2Vw/4qt6l1JSX5gxk/X5RB5/ZDcokGHYB31LXjxHCCGEEPWUopSc2mGxaDnbbm6Xc7gHDIDgYG2CZEnpsYqi7R8woFpKBPbr14958+bh6OhIUFBQYbqIdSQ5JCSEFi1a0KJFC9zd3Rk1ahSHDx/G398f0EaZDx06hIPD5fDRYrGwYMECHn30UZo3b46iKBw9erTIda1pHy4uLjb1MyUlhaSkJMLDwwFtfZTz589zzz33FGlnNptZs2YNgwYNqvh/jBomI9zVRI+e1nGtuel0V15sDacO1a/yNUIIIYSoYno9zJmjvb46l9n6/sMPq60et5ubG82bN6dJkyblLvxyyy230L59+8JqIQcPHmTPnj1s3LixsFpcVFQUmzdvZvfu3fzzzz80aNCA/v3788knn5CdnW13P+fMmYNOp2P48OGAljd+7733FrluVFQU48aNY8GCBXZfpybJCHc1e+m353CfcA/NAmz7q04IIYQQ17CRI+Gnn7RqJFeWBgwO1oLtkSNrrWtXe/bZZ7n77ruZMWMGCxYsoFu3bkUqkljdfPPNLFiwgP/+97/MnTuXnj170qVLF15//XU6duyITqdj9+7dHD16lIiIiCLHZmZmkpCQgMlkIjo6miVLlvDll18ye/ZsmjdvTlJSEr/99hu//vprkWopoFWoGzJkCElJSTRs2LBa/1tUloxwVzOPdH+in36H7450KPHbIyGEEEJcZ0aOhJgY2LABvvtOe46OrlPBNsCdd95JWFgYb731FkuWLGHUqFElths1ahRLliwhPz+fZs2asW/fPm6//XZmzpxJp06d6NKlCx9//DHPPfccb775ZpFjX331VQIDA2nevDnjx4/n4sWL/PXXX4WTK7/++mvc3NyKTO606tevHx4eHnzzzTdV/+GrmKKWV2NPVEhGRgZeXl78zu+44YaKioLCvqATbLlxBF8s9qNBg9ru5fXJZDKxatUqBg8eXO5XaaJmyb2p2+T+1F1yb2qW0WgkOjqa8PBwDAZDmW0tFgsZGRl4enqi08n4Zm0o636lpKTg5+fHxYsX8fT0rPa+yE9ANVNQsGDhhrgWDP3jJLe3z2XTptrulRBCCCGEqCkScFeTL1vmEhTyLG2GzsPwVT5qQwfCVCOvJOzl8X4ZvPYaFBTUdi+FEEIIIUR1k4C7mgyd5EvL81EE/LqMHp0C6bGvKy4d3fHFxH/Zw8aFv9KvH8TG1nZPhRBCCCFEdZKAu5rcfq8L3H239uadd3Bu7EzEts5wKzirOmad80RN+oKOnVSWL6/VrgohhBBCiGokAXc1sVhyYeZM7c2yZXDiBA7uDvT6sxcnh57kaNBRIkc9zcVekxk9xsS04Tv4MehHdvywo3Y7LoQQQgghqpQE3NVEVXOhUycYMkRbbeo//wHAwdGBSb9MwvStiXznfOjyOYwdQpsNcTSMb8jZF+O5snDMsmUQGAg//lhbn0QIIYQQQlSGBNzVxGzO0V68+KL2/NVXRQrcP9X3KT6/83MMDgZeOBhBqwxfABpG+/B/U3az53wkkafO8NhjkJAAjz4KiYk1/SmEEEIIIURlScBdTSyWSwF3jx5wyy1gMsEHHxRpM+m3Segz9dz6z62F28yKGfdf99L1iy50WRJGZqa2PTMTHn+8pnovhBBCCCGqigTc1cRszr38xjrKPX8+JCcXbl4yYgkd4jrgaLm8WIFe1dM6rjVdT3SH5Uswm63ngxUrtBQTIYQQQtR/NZk22rdvX6ZNm1b9FxIlkoC7mhSOcAP07w8REZCTAx99VLj5vg738e6BdzEr5iLHmhUzLy59E8+DdxfZrijw2GOSWiKEEELUd4mJ1Gja6IoVKwqXVe/bty+KovDOO+8Uazd48GAUReH1118vsv3kyZM89NBDBAcH4+zsTHh4OGPHjmXPnj2FbRRFwWAwcObMmSLHDh8+nAcffLDKP1N9IgF3NbFYrhjhVpTLFUs+/hgyMgBIW5OGZb8Fvaovcqxe1eNtdmCRw2ZakVG4XVUltUQIIYSo71QVJk+mRtNGfX198fDwKHwfEhLCokWLirSJi4tj/fr1BAYGFtm+Z88eIiIiOH78OPPnz+fw4cOsXLmS1q1b8+yzzxZpqygKr776avV9kHpKAu5qYjZnF90wYgS0bg3p6fDZZ6iqSvQr0aXeARUV3wIHPmIPQzkPqJfOq6WWHDpUrd0XQgghRDVZtgxWrqRG00avTim58847SUlJYdu2bYXbFi9ezIABA/D39y/cpqoqDz74IC1atGDLli0MGTKEZs2a0blzZ1577TV++eWXItd56qmnWLJkCQcPHqy+D1MPScBdTYqMcAPodPDCC9rrDz5AvZiDMdYIlpKPV1DI1+fjhI5nOMFMDmNA+8284QZo27YaOy+EEEIIm6gqZGfb/oiO1lJJFKXoeaxpo9HRtp3nigrCdnFycmLcuHFFRrkXL17MxIkTi7SLiori0KFDPPvss+h0xcNGb2/vIu979OjBnXfeyUzrN/sCAIfa7sC1qljADXDfffDqqxAbi+67r4jYPRFTkqlYs9RUGDkCYsOXcWvAWh796xEGqEm0IIvX6MC+fa489BDMmwcuLjXwYYQQQghRopwccHcvaY8O8Lb5PKqqfQnetKlt7bOywM3N5tOX6OGHH6ZXr17MmTOHyMhILl68yJAhQ4rkb584cQKA1q1b23ze2bNn07FjR7Zs2ULv3r0r18lrhIxwV5MikyatHB1hxgzt9X/+g6GRHo8bPYo9mtzuwYwvPUg++DDLzt3L9PufJ8U9hXBy+dIhkr5KIl99BQ92SGVri12krkut2Q8nhBBCiHqvY8eOtGjRgp9++omFCxcyfvx4HB0di7SxLsanXD0kX4a2bdvywAMP8Pzzz1dpf+szCbirSYkj3AATJ4K/P5w5Az/8UOrxY8Zoad/6E8M5sOm/PDpmNrENnXAqMPOaephnDSfod+o0BSdz2DclusjqlEIIIYSoGa6u2mjz1Y+MDAvnzqWTkWEp3JaZCUOHgl5f8rn0ehg2rOTzXf1wda2a/k+cOJFPP/2Un376qVg6CUDLli0BOHLkSIXOO2vWLPbt28fPP/9cFd2s9yTgriZ5efFkZu4tfBiNsdoOFxeYPl17PXu2tux7CRQFPvsMPDyA2N5Yft7BwKjuhMwIAeBO43lakwWA/kQmr92/s3DyhRBCCCFqhqJoqR22PNzd4YsvtP+3l5TD7ekJn39u27kqMOBcpvvuu4+DBw/Svn172pYwQaxz5860bduW//u//8NSQsySnp5e4nlDQkJ48sknefHFFzFLgCIBd3XJzNxGZGRE4WPXrlaXg+7HHwcvLzhyBK6a3Xslf39trZxGjeDzzxwICNLR7N1mFMwtKFK726yYCfo9njuHqKSkVPcnE0IIIYS9/P21AbWrv5hWVW37FQVCaoSPjw/x8fH89ddfJe5XFIVFixZx/Phx+vTpw6pVqzh9+jQHDhzgrbfeYtiwYaWee+bMmcTFxbFu3brq6n69IQF3DbFYjJhMl1aZ9PSEJ5/UXr/9dplTjceMgfh4uPvSGjiqqvLdye+K1O7Wq3paZ/iQsns37QdE8vuWM6WcTQghhBC1rTBt9NL/yvV6GDlS214bvL29cStjBma3bt3Ys2cPzZo145FHHqFNmzYMHTqUQ4cO8eGHH5Z6nK+vL88//zxGo7Eael2/SJWS2jJ1KnzwAezZA+vWaatR2qjbD90wK+YiQbdZMfOiMY53W77LXet3sOCESgmpWEIIIYSoZda00Q0btMoknp5a5bHqtHHjxhJflyQqKqrYtpYtW/LVV1+VeVxJ88lmzpwpJQKREe7a07ChtpYraKPcNkpbk0bruNYlr06Z480by97A74fvePhh7fTyR6UQQghR91yZNjp/fs2nkoiaJQF3bXr2Wa1U4MaNsH17uc1tWZ3SKcCJaePuRVG0iRm9emkFUa60bBkEBsKPP1b+IwghhBDCPlenjYprlwTctSkkBB54QHs9e3a5zdV8tdzVKSmAmf9S+fNP6OqZQd/IY/TqXMCaNVqbxERtJauEBG0EPDGxij6LEEIIIYQokeRw17bnn4dFi+D33+HAAejYsdSmOmcdEbsjMCWZuJB1gfErx9PIrRFDWw/l6/1fk2vK5YfHfkDnrKP/7SpuQccwZWTTNT2Vlwa2YtebvuzdCy0yUpnCSeZmNOfxx31ZvrwGP68QQgghxHVGAu7a1qKF9l3S0qXwzjvw3XdlNjeEGDCEGPDAg409NuKkd0JRFB4c9yD55nycHZwxW8z8ceIP+szvw5EHjxIQbeQ9DvDrK4H8SVM+IJowcphoiebxFT4sW6bU2sxoIYQQQohrnaSU1BCdzoCjo1/JO62zd5cuhZMnbT6ns4Nz4VKriqLg7OCMqqpM+m0Sw34YxoeWD+l6oAuNn2wMwFDiWcIuWpMJQGsy6Uoajz0mqSVCCCGEENVFAu5q5O5+AxERkURERNKt2zEMhtCSG3bqBIMHa6tO/uc/lbqmoii08WsDwKxNs3ht52s0m9OcFb06EY8zvpgK25qBiUSTmaHy+OOVuqwQQgghhCiFBNzVKC/vLB4eN+LhcWPpwbbViy9qz4sXw/nzlbrujJ4z+GDABwC8vfVtJi19no+3evMJzYu006ONct9oSWPFCjh0qFKXFUIIIYQQJZCAuxqZTMnk5yfZ1rhnT+jTB0wm+L//q/S1n7n5GT664yMAFh1/j2ZTpjOeWMxXtbOgjXKPHKHSrl2lLyuEEEIIIa4iAfdVMjMz6dq1K507d6ZDhw588cUXdp3H2bkJADk5R2w/yDrKPX8+JCfbdd0rPXXTU8wboi1d5ZuxjdZkor+qjQ5tlLtpahomU7FTCCGEEEKISpKA+yqurq5s2rSJqKgodu7cyezZs0lJSanweVxcWgKQnX3Y9oMGDIAbb4ScHPjoowpfsySTu0zmizu/4OEND6MqxZdcBVCB9ptOMGyoSlZWlVxWCCGEECUwGmPJzNxb6sNojK22ayckJDB16lSaN2+OwWAgICCAXr168dlnn5GTkwNAWFgYiqKgKAouLi6EhYUxZswY1q9fX+I5c3Nz8fHxwdfXl9zc3Grre30nZQGvotfrcXV1BcBoNGI2m1HVkgPVsri4tMRkWktOTgUCbkXRRrlHj4aPP4Z//Qs8PCp87atNbD+RbaZtmNWrE0ouXRbwoIB1f6r07avwxx8QEFDpywohhBDiCkZjLLt2tcJiMZbaRqczlF1owU6nT5+mZ8+eeHt78/bbb9OhQwcKCgo4fvw4CxcuJCgoiKFDhwLwxhtv8Mgjj5Cfn09MTAxLlizh9ttv58033+Sll14qct7ly5fTvn17VFVlxYoVjBs3rkr7fa2odyPcmzdv5q677iIoKAhFUfj555+LtZk7dy7h4eEYDAYiIiLYsmVLha6Rnp5Op06dCA4OZsaMGfj5lVLOrwwuLq2ACqaUAIwYAa1bQ3o6fPZZha9bEp2zjq57uhK0MQjTMleebp3JoxOf4tFHH+X5J1/A9X+u5Cxxwj38LJGR0KMHnDhRJZcWQgghxCUmU3KZwTaAxWLEZKp8WunVpkyZgoODA3v27GHMmDG0adOGDh06MGrUKP744w/uuuuuwrYeHh40atSI0NBQ+vTpw+eff84rr7zCq6++yrFjx4qcd8GCBdx///3cf//9LFiwoMr7fa2odwF3dnY2nTp14pNPPilx/9KlS5k2bRovvfQS+/bto3fv3gwaNIjY2Mtf0URERNC+fftij7i4OAC8vb3Zv38/0dHRfPfdd1y4cKHC/bQG3BVKKQHQ6eCFF7TX778Pa9bA99/Dxo1gLnmE2haGEAOtNrZiwOGbOHjvUE6E/sOJoBPs9tvFTTtvYvzJbly8vymvexzD63QaPXrAzp12X04IIYS4LqiqitmcbdPDYrEt5cJiyS33XBX59j0lJYU1a9bwxBNP4ObmVmIb67oepZk6dSqqqvLLL78Ubjt16hR///03Y8aMYcyYMWzfvp3Tp0/b3K/rSb1LKRk0aBCDBg0qdf8HH3zAww8/zKRJkwD48MMPWb16NfPmzWP27NkAREZG2nStgIAAOnbsyObNm7n77rtLbJOXl0deXl7h+4yMDAAcHcMByM+PIzc3CQcHb5uuCcDdd+Pw3HMoiYkwcGDhZrVxY8wffIA6YoTt57rC4qGLmfT7JAosBZfPifYL66BzYOnFpfhmxtNNn8jdyd3p18+B774zM2RIxVNq6iLTpVmhJpkdWufIvanb5P7UXXJvapbJZEJVVSwWCxaLBQCzOZtt2zyr9Dr79vUqt03Pnhno9SUHz1c7fvw4qqrSokWLwn4D+Pv7YzRqI+5TpkzhnXfeASj8jFfy9vbG39+f6Ojown0LFizgjjvuwMvLC4CBAweyYMEC3nzzTZv6Vd0sFguqqmIymdDri5aNqOnfmXoXcJclPz+fyMhIXrCOEF8yYMAAtm/fbtM5Lly4gIuLC56enmRkZLB582YeL2NVmNmzZzNr1qxi2zdv3kNAQAN0uhT++mshZnNrmz9H4N9/07WkKiXnz6O/5x52P/888TffbPP5rLzx5t3m7/Ls8WeL7Xu3+bvoHfSYtpow9sml1YZU9u4NYNQoPY89tp+BA89U+Hp11dq1a2u7C6IUcm/qNrk/dZfcm5rh4OBAo0aNyMrKIj8/H9AC7tqQkZGBXm/bN9/Z2VofjUZj4cAgwLp167BYLDz66KNkZmaSkZGBxWIp1s7KYrFgMpnIyMjAbDbz1VdfMXv27MK2I0eO5MUXX2T69OnFAtzakJ+fT25uLps3b6agoKDIPusk0ZpyTQXcycnJmM1mAq6a8RcQEEBCQoJN5zh37hwPP/wwqqqiqipPPvkkHTt2LLX9zJkzmT59euH7jIwMQkJC6NevHwkJN5Cevo7OnX0JCBhs24cwm3F44okSdymAqih0/fZbCl5/Hez4Yd6XsA+Ogw4dFi7/9WoOMTP4psGow1QURWGgCaZMsfDVVwrz5nXGx6cDr71moZxvnOo0k8nE2rVr6d+/P46OjrXdHXEFuTd1m9yfukvuTc0yGo2cPXsWd3d3DAYDAKrqQc+exYNTVVXJzMzEw8OjMF0jKyuK/fv7lHudTp024+7eucw2Op1ruWkgl8/XCUVRiI2NxdPz8mi8Nb5xd3fHyckJT09PdDodBoOhSDvQ0lKSk5Np1aoVnp6erFq1iri4OCZOnFikndlsZseOHWVmI9QUo9GIi4sLffr0KbxfVvZUoKuMayrgtrr6B1BVVZt/KCMiIoiKirL5Ws7Ozjg7Oxfb7ujoiJtbO9LT12E0HrP9H8Jt28pcaVJRVTh3DscdO6BvX5v7aRXkFUQj90aEeIYw8YaJvLL+FZJzk3l146v0CevDTcE3Xeo/zH01lxF/HeGpc615+21X4uP1zJ+v7avPHB0d5X9MdZTcm7pN7k/dJfemZpjNZhRFQafTodNdngan1xevKGaxWNDrLTg4uBe2dXCwLQXEwcENR8fKVymzatiwIf379+fTTz/l6aefLjGP2/q5rn5t9fHHH6PT6RgxYgQ6nY5FixZx7733Fqta8s4777Bo0SKGDBlSZf23l06nQ1GUEn8/avr35ZoKuP38/NDr9cVGsxMTE4uNetcEN7e2ABUrDRgfX7XtrhLsGUzM1Bic9E4oisLEzhMZ+sNQknOSCfMOK9L21LSTeJ3LYIF3FA9dvIH9i3L5ZdlJenzfnKC7fO26vhBCCCFq3ty5c+nZsyddunTh9ddfp2PHjuh0Onbv3s3Ro0eJiIgobJuZmUlCQgImk4no6GiWLFnCl19+yezZs2nevDlJSUn89ttv/Prrr7Rv377IdSZMmMCQIUNISkqiYcOGNf0x66x6V6WkLE5OTkRERBTLZVu7di09evSo8f64umoBd4UqlQQGVm27Ejg7OBeO+Ds5OLF8zHI2PriRAPeif5S0WtgK17auOKbn87VfFE8op/DLzmHdvdEkJBSdSLlsmdalH3+0u1tCCCHENc3R0Q+dzlBmG53OgKNjxcsRl6dZs2bs27eP22+/nZkzZ9KpUye6dOnCxx9/zHPPPVdkouOrr75KYGAgzZs3Z/z48Vy8eJG//vqL559/HoCvv/4aNzc3brvttmLX6devHx4eHnzzzTdV/hnqs3o3wp2VlcXJkycL30dHRxMVFYWvry+hoaFMnz6d8ePH06VLF26++WY+//xzYmNjmTx5co331c2tDQB5eWcoKMjCwcG9/IN694bgYC2tpLSSP3o9VZlM7eZU9KullUdWcnvT2/Hw86DTuk5E9Yki92QuTdGqsYTmZPLoDWn832ZfWrSAxER47DGtdPijj8Itt4C/f5V1TwghhLgmGAyhdOt2rMw6246OflW+6I1VYGAgH3/8MR9//HGpbWJiYso9z7PPPsuzzxYvwADaxNKazo+uD+rdCPeePXu44YYbuOGGGwCYPn06N9xwA6+++ioA99xzDx9++CFvvPEGnTt3ZvPmzaxatYomTZrUeF8dHRvg6KhFnrm5x8ppfYleD3PmaK9LC6rNZrj1Vnj9dbhq1m1lzdkxh5HLRjL6x9GYzCacA53puK4jitPlvpiBwQnR9LhZZccOmDwZMjO1fZmZUEZRFyGEEOK6ZjCE4uFxY6mP6gq2Re2qdwF33759CyuIXPlYvHhxYZspU6YQExNDXl4ekZGR9OlT/ozg6mLN465QWsnIkfDTT9C4cdHtISGwZAlMmAAWC8yapU2cPFN1Jft6hPTA1dGVNafWMOm3SaiqSu7RXNT8y6PteqA1mYSnpNGnD6xceXlNHrMZVqzQUkyEEEIIIUQ9DLjrG2sed4UmToIWdMfEwIYN8N132nN0NIwbB4sXw7ffgoeHVtWkU6cqS57u2rgrP979I3pFz9f7v+aV9a8Q/Uq0FmVf5Rn305hMxdNeFEVLMUlMrJIuCSGEEELUaxJwVzNXVy2Pu8JLvIOWXtK3L4wdqz1fWXf7vvsgKgpuugkuXoQxY2DSJMiufAH+wS0G8/ldnwOwZvEaMndnankkVwnMyqIHxfO0VFVSS4QQQgghrCTgrmaXSwMeqfqTN20KW7bAiy9qw8oLFkBEBOzbV+lTT7xhIrNumcXE9ROxKJZS283kCI4lROPW1JJDhyrdFSGEEEKIek0C7mpmTSnJzT2F2Wys+gs4OsJbb8Fff0FQEBw7Bt27w3//q+V5V8JL3V+iSU4TdGrpPybumJlEdLHter2WFdOuXaW6IIQQQghR70nAXc2cnAJwcPABLOTmHq++C/XrBwcOwLBhkJ8P06fDkCFw4YLdp9Qb9PSJ6oNxpZGIyAgiIiNY/9F6Hn30UdZ/tJ5G77bgqM6DJRSvAOPiAvPmVeYDCSGEEEJcGyTgrmaKoti3AI49GjTQSoZ8+ikYDPDnn9qEytWrtf1mM2zcCN9/rz2bS0jMvopbEzfa9G3D8UbHORF4gs+Mn3Ei6ATz8+aTM/4CaQtUMr3irjhCm0RpsUBy6WVGhRBCCCGuG/Vu4Zv6yM2tDRkZ2ypeqcQeigJTpkCfPnDvvVoS9R13wF13wd692oI6VsHBWs3vkSPLPGXYnLBi25Kyk4j4/NIysM+A/k2V4eZzBCs5fOPdgtQ0hTvugO3btcsIIYQQQlyvZIS7BlwuDVgNEydL07497N6tBd8Av/1WNNgG7f3o0drsxjIsGbEEB13Rv83USyPZDjoHPr1tCW1cs5nCSYarcfz1VgqtWsHZszBokLYCpRBCCCHE9UoC7hpg1+I3VcHFBT76SEs1KYl16fhp08pMLxnXcRw7J+0scd/OSTuZ0mscr3zpxpeeLcke3YROkxvw55/QqBH88w8MHw7GapgvKoQQQgjbPPjggyiKwuTJk4vtmzJlCoqi8OCDDxZuS0hI4KmnnqJp06Y4OzsTEhLCXXfdxV9//VXYJiwsDEVR2LFjR5HzTZs2jb59+1bXR6mXJOCuAZcrlRzHYjHV7MW3bIGU4rWyC6mqNhS9ZYtNp9Nd9SOTmaet6T5mDHx3MYghP4ajKAphYbDqd5VeLqk8uGkXLw5MrWzRFCGEEOKasiduD7d+dSt74vbUyPVCQkL44YcfyM3NLdxmNBr5/vvvCQ29vKR8TEwMERERrF+/nv/85z8cPHiQP//8k379+vHEE08UOafBYOD555+vkf7XZxJw1wBn52D0endUtYDc3JM1e/H4+Cpp5+/mTyP3RkQERfDfgf/FSe8EwJydc0psb842o7ywnzc8jhFGDi03R/PMNLVwUF0IIYS43n29/2s2xGzgm/3f1Mj1brzxRkJDQ1lxRSrpihUrCAkJ4YYbbijcZh3x3rVrF6NHj6Zly5a0a9eO6dOnFxvNfuyxx9ixYwerVq2qkc9QX0nAXQO0SiXaipM1mscNEBhYJe2CPYOJmRrDzkk7mdZ9GusfWI+CwsqjK/n2wLfF2icuTSR9XTpKYh4Arcnk74/TeO+9Cn8CIYQQos7Lzs8u/jBpz8aCy3mVZ9LPsPXMVrbFbuOHf34A4Pt/vmdb7Da2ntnKseRj5Z63Mh566CEWLVpU+H7hwoVMnDix8H1qaip//vknTzzxBG5ubsWO9/b2LvI+LCyMyZMnM3PmTCzyVXappEpJDXF1bUtm5m6ysw/TsGHZVUGqVO/eWpmQ8+cpcXhZUbT9vXuXeypnB+fC1z1De/LaLa/xy7FfiAiKKNY24MEATr94GtMFLYVGVWCiGs3jz/sQGKgwfrz9H0kIIYSoa9xnu5e6b3CLwfxx3x9AKZW/cpLotahX4Xv1tcv/vw6bE0ZyTtE6u1fur6jx48czc+ZMYmJiUBSFbdu28cMPP7Bx40YATp48iaqqtG7d2uZzvvzyyyxatIhvv/2W8fI/+BLJCHcNubzEew1PnNTrtdJ/oAXXV7K+//BDrV0FvdTnJf5++G9a+xX/pUxfm14YbAMoqjbK3ZU0Jk6ENWsqfDkhhBCi3lsyYkmZ+1s3sD3QtYefnx9Dhgzhq6++YtGiRQwZMgQ/P7/C/eqlwTnl6pihDA0bNuS5557j1VdfJT8/v8r7fC2QEe4aYk0pqfFKJaDV2f7pJ5g6Fc6du7w9OFgLtsupw10aB51DkXKB5zLOEewZjKqqRL8SDXrgquInL7sdZ1j2TYwapbBpE9x4o12XFkIIIeqUrJlZRd5bLBYyMjPw9PDE0cGxcPu4juMI8w4rMqJttfWhrdwYWPR/jDFTY6q8rxMnTuTJJ58E4NNPPy2yr0WLFiiKwpEjRxg+fLjN55w+fTpz585l7ty5VdnVa4aMcNeQyyPcR1HV8ld4rHIjR0JMDPz3v9r7oCCIjrY72L6Sqqq8uuFVms5pypYzW0hbk0bm7sxiwTaAZ7aRN5ucJitLq9F9+nSlLy+EEELUOjcnt+IPR+3Z4GAo0tbF0QW4XPnL+uzi6FK4r6zzVtYdd9xBfn4++fn5DBw4sMg+X19fBg4cyKeffkp2dvF88fRSFtdwd3fnlVde4a233iIjI6PSfbzWSMBdQwyGMHQ6A6qah9EYUzud0Ou1otigrbtega+LyqIoCrEXYzFZTNy/4n5OvHSizJ+sXmfOMiH0AomJMHAgJCVVSTeEEEKIeuHKyl+fDfmMiKAIGrk3wt/Nv0aur9frOXLkCEeOHEFfQkrp3LlzMZvNdOvWjeXLl3PixAmOHDnCRx99xM0331zqeR999FG8vLz4/vvvq7P79ZKklNQQRdHj6tqarKwosrMP4+LSrHY60rgx6HSQnw8XLthexaQcHw/6mK2xW4lNiiXlZAquFtcy2z947ghZfgrLT/ozZAhs2AAlTIYWQgghrjnWyl9OeicUReHRiEfJN+cXKU5Q3Tw9PUvdFx4ezt69e3nrrbd49tlniY+Pp2HDhkRERDBv3rxSj3N0dOTNN9/kvvvuq44u12sScNcgV9e2ZGVFXZo4eVftdMLRUUsnOXcOzpypsoDbw9mD70Z9R8+FPXlw4oN82PVD7mpV/DOqZpXYd2NJXp7Mk+lHyHZX+HN3Q8aMgZ9/1ronhBBCXOuuDK4VRan2YHvx4sVl7v/555+LvA8MDOSTTz7hk08+KfWYmJiYYtvGjh3L2LFj7ejhtU1SSmpQrU6cvFKTJtrzmTNVetpujbvxRt83SPJK4tHoR7kQdgGPGz2KPDy7etJuaTsC7g+AApXnDSfwMphZtQomT75cuXDZMu1vgR9/rNIuCiGEEELUOAm4a9DliZM1vPjN1awBd2xslZ96Rs8Z9A3rS7Ypm7HLx2IyF1/KXtErtF7cmsZPNqbrxk58vVSPTgcLF8Krr0JiIjz2GCQkwKOPau+FEEIIIeorCbhrkKurFnBnZx8urHNZK6pphBtAr9PzzYhvCPYM5tEbHy1SNvBKil6hxcctcGvnxtCh8Nln4EoB//63NpEyM1Nrl5kJjz9e5d0UQgghhKgxEnDXIBeXZiiKIxZLNnl5Z2uvI9UYcIM2GeTkUyd5JOKRwsL5e+L2cOtXt7Inbk+Jx4xukcbPLjvoSiq6qFS+NO/iRlIxm2HFCi3FRAghhBCiPpKAuwbpdI64uLQAajmPu5oDbig6GSTdmM4XkV+wIWYD3+z/psT2CQsScMwtYBjneYRowsjhEaIBFUXRUkwktUQIIYQQ9ZEE3DWsTuRxh4Zqz9UYcAOcST/DV1Ff0ebTNny1/ysAfjj0A3vj9xIZF8mZ9MvXb/llK7a1DWeVEkhrtHwS61LwqiqpJUIIIYSov6QsYA2z5nFrpQFriXWEOyMD0tPB27taLhM2J6zYtqTsJCI+jyh8r76m5bIfOaHj5cOhzGMvZi6vCj+RaHbjg9mssGIFHDoE7dpVS3eFEEIIIaqFjHDXMOsId62mlLi5QYMG2utqHOVeMmJJsUmTKlqA7aBzYMmIJYXb27WDqT3SaE0m1jWv9Fwe5dbrtVXoJdgWQgghRH0jAXcNu3KEu05UKqmG0oBW4zqOY+eknSXu2zlpJ+M6jrtii8q9OdGYr2pnQRvldndTKWNxKyGEEEKIOksC7hrm6toS0FFQkE5+fkLtdaQGJk5eSUEpc3/amjSMUZdHt610aKPco5qk4e9fbd0TQgghhKg2EnDXMJ3OGReXZkAtT5ysoYDb382fRu6NuDHwRvxc/QBwd3LH3+1y9KyqKtGvRJf602gBuh6MZuOGWvxGQAghhKjHHnzwQYYPH17ivrCwMBRF4Ycffii2r127diiKUmxp+H379nH33XcTEBCAwWCgZcuWPPLIIxw/fhzQln1XFAV/f38yrYtrXNK5c2def/31qvhY9YYE3LXgygVwak0NVSoJ9gwmZmoMux/ZzQcDPgBgaMuhBHsGF7ZR81WMsUYtsi6BDmiIkacmq+TnV2t3hRBCiBqTui6VXW13kboutba7QkhICIsWLSqybceOHSQkJODm5lZk+++//0737t3Jy8vj22+/5ciRI3zzzTd4eXnxyiuvFGmbmZnJ+++/X+39r+ukSkktcHNrS0rKL3WjUkkNpJRYa3Lf1+E+Wvu1pmvjrkX265x1ROyOwJR0eRn4tWvgk/8U8HLOQXR5Fla4h/HPcR3vvw8vvljtXRZCCCGqlaqqRL8YTc6RHKJfjMbnNp/CxeJqw7hx4/jvf//L2bNnCQkJAWDhwoWMGzeOr7/+urBdTk4ODz30EIMHD2blypWF28PDw7nppptIT08vct6nnnqKDz74gCeeeAL/6zg3VEa4a4Graxvg2l/85mp6nb5YsG1lCDHgcaNH4WPkCx6sT/Wh6YvaSPyDnufRofLmm3D6dI11WQghhLCJOdtcoUfKrylk7tZSLTJ3Z5LyvxRtX6653PNWh4CAAAYOHMhXX2nrZuTk5LB06VImTpxYpN3q1atJTk5mxowZJZ7H+6pSw2PHjqV58+a88cYb1dLv+kJGuGtBnVj8xhpwX7gARiMYDDV6+bjMOHaf382w1sPKbBc8LZhzc85BXA5PtbnAnCONeOIJWLUKanEgQAghhChii/uWih+kQ0un1MPJp09iPGXE6xYvbth4Q2GTHWE7MCWbihzWV+1bqb6WZuLEiTz77LO89NJL/PTTTzRr1ozOnTsXaXPixAkAWrdubdM5FUXhnXfe4a677uKZZ56hWbNmVd3tekFGuGuBq6v2Q2oyJZKfn1w7nWjQAFxdtddnz9bopY8mH6XZR80Yu3wsCVllV2px8HQg9HltlHtUVgwujhb+/BOWL6+JngohhBDVyDp3yQzGU8Za7QrAkCFDyMrKYvPmzSxcuLDY6DZgV0njgQMH0qtXr2L53dcTGeGuBXq9GwZDGEZjDDk5R3By6l3znVAUbZT7yBEtraRFixq7dKsGregU0Imd53fyztZ3+PCOD8ts3/iJxpz9v7OYzhr54M4EHv89iKlTYcAA8PSsmT4LIYQQZemdVfT/5RaLhYyMDDw9PdHpLo9vqqpK1C1RZO3PosjiE3pw7+ROh1Udipyne0z36ux2EQ4ODowfP57XXnuNnTt3FsnRtmrZsiUAR48e5eabb7b53O+88w4333wz//rXv6qsv/WJjHDXEmse9/UycfJKiqLw71v/DcC8PfM4e7HsEXa9m54mL2p97bjvDK3CzcTFwauvVntXhRBCCJvo3fQ2PTK2ZZC196pgG8AMWXuzyNiSUe55q9PEiRPZtGkTw4YNw8fHp9j+AQMG4Ofnx3/+858Sj7960qRVt27dGDlyJC+88EJVdrfekIC7BA4ODnTu3JnOnTszadKkarnG9VQasCS3hd/GLU1uId+cz1tb3iq3feBjgTg1diL/fB6fjEoC4OOPYe/e6u6pEEIIUTXKW3cCHUS/El1tK1FfvHiRqKioIo/Yq1acbtOmDcnJycVKBFq5ubnx5Zdf8scffzB06FDWrVtHTEwMe/bsYcaMGUyePLnU67/11lusX7+eY8eOVennqg8k4C6Bt7d34Q/il19+WS3XqFMTJ2sh4FYUhTf7vQnAgn0LOJ1WdukRvUFPizktaPtjW257N4B77wWLBSZPBnP1TNgWQgghqlR5605gAeNZI2p+9QTcGzdu5IYbbijyeLWEr4sbNGiAi4tLqecZNmwY27dvx9HRkfvuu4/WrVszduxYLl68yL///e9Sj2vZsiUTJ07EaKz9fPWaJjnctaROjHDXYsAN0LtJbwY2G8jqU6t5Y9MbLB6+uMz2DUc1LHz9wQdapZLdu2H+fJgypZo7K4QQQlRSSetOXM3R3xGdc9WPhy5evLjYapG2KilNpEuXLiwvo4JBWFhYiSP18+fPZ/78+Xb1oz6rdyPcmzdv5q677iIoKAhFUfj555+LtZk7dy7h4eEYDAYiIiLYsqVipXoyMjKIiIigV69ebNq0qYp6XpSbm5bDnZ9/noKCi9VyjXJZA+6rvk6qSW/2exMXBxcC3AIq9BWav6eZ2a9pQ9szZ0JC2cVOhBBCiDrh6nUnrn4Ygmu2TK+oGfUu4M7OzqZTp0588sknJe5funQp06ZN46WXXmLfvn307t2bQYMGFclRioiIoH379sUecXFxAMTExBAZGclnn33GAw88QEZGRonXqgwHBy+cnIIufaZaSiuxBtxnz9ZaXkbXxl05P/087/Z/1+YVti58e4EdTXcwKOssXbpARgZMn17NHRVCCCGEsFO9SykZNGgQgwYNKnX/Bx98wMMPP1w42fHDDz9k9erVzJs3j9mzZwMQGRlZ5jWCgrRAuH379rRt25bjx4/TpUuXEtvm5eWRl5dX+N4anJtMJkym0r8yAnBxaUN+fhyZmf/g6hpRZttq0bAhDg4OKAUFmGJjITi45vsAuDu4l/vf6kpm1Ywp0UTyL0l8/GkQPXs68v33CuPHF3D77aWPkluvUZFriZoh96Zuk/tTd8m9qVkmkwlVVbFYLFgspSVia6zf2lrbi5pnsVhQVRWTyYReX7S6S03/ztS7gLss+fn5REZGFis5M2DAALZv327TOdLS0nB1dcXZ2Zlz585x+PBhmjZtWmr72bNnM2vWrGLbN2zYgKt1YZlSGAwuODvDoUN/EBnZsMy21eV2X1/cEhPZsXQpqW3a1EofrI5mHyUqM4p7G91bdkM3cHzWkYs3X4QLcQwe3J7ff2/Gww8bmTNnA05OZf/Dtnbt2irstahKcm/qNrk/dZfcm5rh4OBAo0aNyMrKIj8/36ZjMjMzq7lXojT5+fnk5uayefNmCgoKiuzLycmp0b5cUwF3cnIyZrOZgICAItsDAgJIsDHJ98iRIzz22GPodDoURWHOnDn4+vqW2n7mzJlMvyKfISMjg5CQEPr160eDBg3KvFZCwnlOnfqdRo3yaNt2sE39q2r6Vq0gMZGbg4JQB9dOHwDOZZxj5KcjsagWnr7jaboElfyNQqE7L7/s1Qs6dlSJi3PnwIHBvPpqyQG3yWRi7dq19O/fH0dHxyrsvagsuTd1m9yfukvuTc0yGo2cPXsWd3d3DIayc61VVSUzMxMPDw+bUyZF1TIajbi4uNCnT59i9yslJaVG+3JNBdxWV/9gq6pq8w97jx49OHjwoM3XcnZ2xtnZudh2R0fHcv/x8/BoD0Bu7pHa+4cyLAy2bMHh/HmoxX+swxuEM77jeL7a/xWztsziz/v/tOk4S74Fh+OZzJnjxd13w3/+o2f8eD2XFsIqkS33RtQOuTd1m9yfukvuTc0wm80oioKiKEVWjyyJNY3ElraieljvVUm/HzX9+3JN/QT4+fmh1+uLjWYnJiYWG/WuC6ylAY3GM5jN2bXTiTpQqcTq1VtexUHnwOpTq9lypvzKMnkJeexqtYv9t+7nzpvzGDQI8vO1EoHVtGaAEEKI65g1SKvpdARhH+t9qgt/jF5TI9xOTk5ERESwdu1aRowYUbh97dq1DBs2rBZ7VjInJz8cHRtiMiWRk3MMD48ba74TtVyL+0pNfZry8A0PMz9yPi9veJmNEzaW+c2EU4ATTo2dMMYYOftOLJ980oJ27eCvv+D77+G++2qw80IIIa55er0eb29vEhMTAXB1dS31/1MWi4X8/HyMRqOMcNcwVVXJyckhMTERb2/vYhMma0O9C7izsrI4efJk4fvo6GiioqLw9fUlNDSU6dOnM378eLp06cLNN9/M559/TmxsbJlLjdYmV9e2XLy4iezsw9d9wA3wcp+XWRy1mM1nNrPu9Dr6N+tfaltFUQj/dzj7++0nbn4cNz0XwiuvGHjpJXjmGRg0CHx8arDzQgghrnmNGjUCKAy6S6OqKrm5ubi4uEgOdy3x9vYuvF+1rd4F3Hv27KFfv36F760TFidMmMDixYu55557SElJ4Y033iA+Pp727duzatUqmlgDyzrGzU0LuHNyamnFySsDblWFWv5HIdgzmMldJjNn5xymrZ5GgFsA/+n/n1InUfr09cH7Vm/S16dz/PHj3BZtZHdoc36O9eXFF2HevBr+AEIIIa5piqIQGBiIv79/maXlTCYTmzdvpk+fPnUipeF64+joWCdGtq3qXcDdt2/fclcknDJlClPqyVrfrq5aKb5aW+I9JIRLHYDUVCinskpNmNlrJmtOraGReyPWR6/nm/3flFm1JPzNcPat30fq/1IBmNoqmp/xYf58hQkToHv3muq5EEKI64Very8zoNPr9RQUFGAwGCTgFtfWpMn6yM1NmziZk1NLq026uIC/v/a6DqSVnEk/w7mMc3wz4hv+SfwHgB8O/cDe+L1ExkVyJr14H716eOHe1f3yhmOZzLw9DVWFyZPhqtKbQgghhBA1qt6NcF9rrJVKcnNPYrHkodMVLzFY7Zo0gcRELeC+sRbyyK8QNies8LWClt6SlJ1ExOeXV+JUXyv6DYeqqliyr6i9rYOhydF85u3D/v0KH3+s5XQLIYQQQtQGGeGuZU5OjXBw8AYs5OQcr51O1KHSgEtGLMFBp/0dqKIWeXbQObBkxJJix6StSSPn8BUlmixgjMrkkwlpALzyCpw9Cz/+qPDggwP56SeZvCKEEEKImiMBdy1TFKUwj7tOTJysZeM6jmPnpJ0l7ts5aSfjOo4rsk1VVaJfiYar0+j00HJbND1uVsnO1lJLpkzRk57uzJQpesqZXC6EEEIIUWUk4K4DrGkl2dm1lMddhwLuK+ls+PFMW5NG5u5MMF+1wwxZezL56IE0dDpYtQoyMwEUMjPh8cero8dCCCGEEMVJwF0HXJ44WQ9HuM1m2LhRW2lm40btfSX5u/nTyL0REUER9AvTSkC6OLjg7+ZfpF3h6HZpP8U6YGE0QwZrKSkWi3KpyworVsCyZZXuqhBCCCFEuWTSZB1weYS7lgLu0FDtuaIB94oVMHUqnDt3eVtwMMyZAyNH2t2dYM9gYqbG4KR3YkPMBjbEbMDN0Y1A98Ai7dR8FWOsESylnMgCOWeMbD+mAkXzthUFHnsM+va9XKRFCCGEEKI6SMBdB7i5aTncubnHsVhM6HQ1XK/TOsKdnKzV43ZzK/+YFStg9GhtsZwrnT+vbf/pp0oF3c4OWrWW3qG98TZ4k5ybzI5zO+gZ2rOwjc5ZR8TuCExJRRceuLjlIu6d3dG563nyZUfS1xYfAldVClNLli+3u5tCCCGEEOWSlJI6wNk5BJ3ODVU1kZt7quY74O0NHh7a67Nny29vNmsj2yUtQGTdNm1alaSXOOodGdJiCAC/HPul2H5DiAGPGz2KPIKnBuN9izexzh5886eh1G6YzdrfDYcOVbqbQgghhBClkoC7DlAUXeEod60sgKMoFcvj3rKlaBrJ1VRVC9y3bKmS7g1tNRQHnQNpuWkVOq5dO7j7LjOlLQSm12uD8O3aVUEnhRBCCCFKIQF3HWHN464XEyfj4207p63tyjG01VASn0vki6Ff2HzMxR0Xieyyhxk5h/Dw0P6muJKigKcnzJtXJV0UQgghhCiVBNx1hLVSSa1NnKxIwB0YWH6birQrh8HBgI+LT4WOcWzgSNbeLHK2pTP/fVOx7BdVhc8+kwmTQgghhKh+EnDXEbW++E1FKpX07q1VI7l62NhKUSAkRGtXxVJzU21q59rClbY/tKX72e7cPdGRESNAr78cdev1MGRIlXdPCCGEEKIYCbjriMspJUdR1cpPNqywioxw6/Va6b+SJk1ag/APP6TU5Gk7GAuM9FjQA//3/LmQdcGmY/zv8cfJzwlF0Uaz3d0BVHQ6tXDCpBBCCCFEdZOAu45wcQlHUZyxWIwYjbWw4mNFF78ZORK6di2+3cOj0iUBS2JwMJBvzsesmvn9+O8VPt7P28LcuWa8vfMYOVIr3L14cZV2UQghhBCiRBJw1xGKosfVtTVQS3nc1oD7/HkoKCi/vdF4uZ7e559fXivd3x9GjKiWLg5rNQyAX4//avMxGTsz2Nd7H0fGHeHuu1UWL17N7NlawL1+fZ1bzV4IIYQQ1yAJuOuQy6UBayHgbtQInJzAYtGC7vKsXw85OVou96RJ8O674OICJ0/Cnj3V0sVhrbWAe+2pteSYcmw6Ruei4+LWiyT/kkx+Yj6g/W1x663a/m++qZauCiGEEEIUkoC7DqnVJd51Om2iI9g27Pvbb9rznXdqedseHjB8uLZtyZJq6WIH/w6EeYeRW5DL2lNrbTrGvaM7Hl09UE0qSd8mFW5/8EHtefHiklPRhRBCCCGqigTcdYi1NGCtLH4Dtudxqyr8fimP+q67Lm+//37t+fvvwWQqflwlKYrC0JZDgZJXnSxN4CStPOGFhRfgUnA9cqQ2ifLUKdi2rcq7KoQQQghRSALuOuTKxW/U2hh2tbU0YFSUttKkq+vl3AyA/v2hYUNISoJ166qli9a0kt+P/47ZYls1F/97/dG56sg9lov+qFY5xc0NxozR9svkSSGEEEJUJwm46xAXl+YoigNmcxZ5eWUsnV5dbB3htqaT9O8PBsPl7Y6OcM892utvv636/gG9Q3szrsM43h/wPmYbyyc6eDrgf4+2wo3TWqfC7RMmaM/LlkF2dpV3VQghhBACkIC7TtHpHHFxaQHU0sRJa8AdG1t2O2vAfWU6iZU1rWTlSsjKqrq+XeKod2TJyCU80OkBnPRO5R9wiTWtxHGbIwUXtSosvXpB06aQmal1VwghhBCiOkjAXcdcnjhZC3nctoxwx8VdrkIyeHDx/d26QfPmWgWTn3+u8i7ay/NmT1xau6DkKSQvSwa0eaLWUW5JKxFCCCFEdZGAu465PHGylke4S8sh/+MP7blrVwgMLL5fUS6PcldTtRKAEykneG/be5xKPWVTe0VRCJgYAFyaPHnJAw9oz1KTWwghhBDVRQLuOqZWSwOGhGgBc26uNvGxJGWlk1iNG6c9r10LF2xbhr2invrfU8xYN4OfDv9k8zH+4/xRHVSyIrPIjMoEICwM+vXT/r6QmtxCCCGEqA4ScNcxVy5+U+OVSpycLo9alzTcm5t7ufpIWQF38+Zw003aIjo//FD1/QSGttLKA1Zk1UnHho6YumnlChMWJBRut9bk/uorqckthBBCiKonAXcd4+LSEtBRUJCGyZRY8x0oqzTgX39pQXdICHTqVPZ5qjmtxBpw/332by5k2T6KbuqvBdwXllzAnKtVORk1SqvJffIkbN9e9X0VQgghxPVNAu46Rq93wcWlKVBLaSVlTZy0LnZjXV2yLGPGgF6vTbA8dqxq+wgEewYTERiBisrvx3+3+biCTgW4tnel4ZiGmLO0gNvNDUaP1vbL5EkhhBBCVDUJuOugKxfAqXGllQYsbXXJ0vj7w8CB2utqqsk9rJW2CE5FVp1EB533dKbV/FY4NbxcVtCaVrJ0qVZgRQghhBCiqkjAXQe5ump53HVqhHvfPjh/XhsO7tfPtnNdmVZSDcnR1rSStafXkmOyPUpWdMVH53v3hvBwqckthBBCiKonAXcdVCdKA14dcJe2umRZhg3TkqOjo+Hvv6uuj5d0DOhIE68mKCgcvHCwQseqqkrGrgySVmrVWKQmtxBCCCGqiwTcdVCdXPzGlnKAV3N1hREjtNfVkFaiKAp/3PcHyTOSuSn4pgodm7o6lb037eXYw8fY1WYXqetSC2ty//VX+YttCiGEEELYSgLuOsjVtTUAJtMFTKaUmr24tUpJWpqWXwHa6pKRkdpEySFDKnY+a1rJ0qWQn191/byknX87XB1dK3ycz60+OIU6gQ5yjuYQ/WI0YWEqfftKTW4hhBBCVC0JuOsgBwd3nJ21keYaH+X29ARvb+21dZTbOlmyWzcICKjY+W69FRo1gpQUWL26yrpZkgJLgc1tdU46Ws5rSUGKdkzm7kzS1qRJTW4hhBBCVDkJuOuoKxfAqXFXVyqxJ53EysEBxo7VXn/wAXz/PWzcCGZzpbtp9eOhH2k/tz0v/vWizceoqsqZ18+A/tIGPUS/Es3IkSpubnDiRLWknQshhBDiOiQBdx11uTRgLedx5+TYtrpkWayrV27cCPfdp1U5CQuDFSsq21MAVFQOJR2qUHnAtDVpZO7OBGvcb9ZGuU3b06QmtxBCCCGqlATcVzl27BidO3cufLi4uPDzzz/XeD+slUpqvTTgX3+B0ajldnfoUPFzrVgBzz9ffPv589pqM1UQdN/R/A4cdY4cTznO0eSj5bZXVZXoV6Ivj25bXRrlfnCClksiNbmFEEIIURUk4L5Kq1atiIqKIioqiq1bt+Lm5kb//v1rvB91YvGbM2cup5PYsrrk1cxmmDq15GRo67Zp0yqdXuLp7Mmt4bcC8MvR8ke509emFx3dLuyvNsrd3phGWBhkZEAt/K0lhBBCiGuMBNxl+PXXX7nttttwc3Or8WtbF7/JyztHQUFGzV7cGnDHxFRsdcmrbdkC586Vvl9V4exZrV0l2bzqpAqxr8WW/pOvgzOvRTPhAe0PAkkrEUIIIURl1buAe/Pmzdx1110EBQWhKEqJ6R5z584lPDwcg8FAREQEW+wM6JYtW8Y999xTyR7bx9HRGycnLfe5xvO4GzfWnnfuhPh4rZ52374VP098fNW2K8NdrbQ/CHac28GFrAulNyyAvLN5YCllvwWMZ42Mv1cLuNet0/4mEEIIIYSwV70LuLOzs+nUqROffPJJifuXLl3KtGnTeOmll9i3bx+9e/dm0KBBxF6xkklERATt27cv9oiLiytsk5GRwbZt2xg8eHC1f6bS1MoCOCtWwKhR2mtr2ofFAqtWVfxc1smSVdWuDMGewUQERqCi8tvx30pv6Aid/u5ERGRE4aPzls4ozlq6TOtvWhOxO4JmbXTccovU5BZCCCFE5TnUdgcqatCgQQwaNKjU/R988AEPP/wwkyZNAuDDDz9k9erVzJs3j9mzZwMQGRlZ7nV++eUXBg4ciKGcZczz8vLIy8srfJ+RoaV/mEwmTCZTudcpi4tLa9LT/yIr62Clz2ULZeVK9PfeC6rKldnaqtEIo0dj/uEHVOvKkbbo3h2Hxo0hLg6lhDxuFSA4mILu3aEKPt+49uNo69eWlj4tS/zvZd2ma6TDMcSxyD7fu3xJ+SmFjD0ZNLinASaTifHjFTZtcmDxYpXnniuocAq7sJ313tTEz7moOLk/dZfcm7pL7k3dVtP3pd4F3GXJz88nMjKSF154ocj2AQMGsH379gqda9myZTz66KPltps9ezazZs0qtn3Dhg24ulZ8BcQrOTkV4OICMTGbOXzYjhHmijCbGTBlCvqrgm0ABa2yR/4TT7DWwQH0V5f3KF3g/ffT9d13US+dx8r6PqZVK/ZX0YI4TWlKU31Tdu/YzZNxTzIhaALNXZsXa7d27dpi2xxaOOCGG+e+OceRPkdAD25uegyGOzhxwoH//vdvWrdOq5J+itKVdG9E3SH3p+6Se1N3yb2pm3JquAzZNRVwJycnYzabCbhqNcSAgAASEhJsPs/FixfZtWsXy5cvL7ftzJkzmT59euH7jIwMQkJC6NevHw0aNLC98yX2w51//pmPu3sKfftWb2qLsmkTDimlLyOvAK7JyQzx9ES95RbbTzx4MOYbb0Q/fbpWCtDKywsuXqTJxo0EP/88qj054qV4Zs0zHDx+kBjPGJ4e8HThdpPJxNq1a+nfvz+OjkVHuC23Wdg1bxekQk/Pnnjd4gXAH3/oWLIETp7syfTppSV+i8oq696I2if3p+6Se1N3yb2p21LKiHmqwzUVcFspV333r6pqsW1l8fLy4sKFMibeXcHZ2RlnZ+di2x0dHSv9C+bp2RGAvLwYdDoTen3lRszLlJRkUzOHpCSo6OcaM0bLC9+yRZsgGRiI0qsXPPQQypIlOIwdC3v2aIvh2OlM+hmSc5IB+O6f7wBYdmQZD934EKqq4ufqR5BbEFDKvXGEhiMbkrAwgZQfU/C73Q+AiRNhyRJYtkzPRx/pcXGxu4vCBlXxeyOqj9yfukvuTd0l96Zuqul7ck0F3H5+fuj1+mKj2YmJicVGvesDJ6eGODr6YTIlk5NzDA+PG6rvYtU9wVGvL17p5PPP4cgRiIyE4cNh2zawswRj2JywYtuSspOI+Dyi8H3+i/llniPgvgASFiaQ9GMSLT5ugc5JmzjZpIlWkvznny+vUi+EEEIIYat6V6WkLE5OTkRERBTLl1q7di09evSopV5VTo0tgNO7NwQHl764jaJASIjWrqq4uMDKleDvD/v3a8PJJS2SY4MlI5bgoCv696OqTcvEQefAkhFLyj2Hd19vnBo5UZBWQOqaVAB0OpgwQdsvNbmFEEIIYY96F3BnZWUVrgQJEB0dTVRUVGHZv+nTp/Pll1+ycOFCjhw5wjPPPENsbCyTJ0+uxV7bz7oATrUv8a7Xw5w52uurg27r+w8/rNCESZuEhMDy5VqayrJl8PbbsHEjfP+99mzjKpTjOo5j56SdJe7bOWkn4zqOK/ccil6h4ZiGACR+n1i4/YEHtOe1a8tex0cIIYQQoiT1LqVkz5499OvXr/C9dcLihAkTWLx4Mffccw8pKSm88cYbxMfH0759e1atWkUT6+qJ9Yybm3WEuwZqcY8cCT/9pC3HfmVkGRysBdsjR1bPdXv1go8/hsmT4eWXi+4LDtb+ELDj2gpK4Si3rRpNaITiqBAw7nIKUrNm0KcPbN6s1eSeObPCXRFCCCHEdazeBdx9+/ZFLSftYMqUKUyZMqWGelQ9jMZYTKZkQEvqz8zcS2bm3sL9jo5+GAyhVX/hkSNh2LAiExzp3bvqR7av1rBhydvPn4fRo7U/BMoJuv3d/Gnk3ggFhfisePxc/dDr9Pi7+dvcDY8bPfC40aPY9gcf1ALuxYvhhRdKz7wRQgghhLhavQu4rwdGYyy7drXCYjEWbsvLO0Nk5OUJgDqdgW7djlVP0F3SBMfqZDZro+olUVUtup02TftDoIzAP9gzmJipMfx46EfG/zyeVg1ase6BdTg7FK8iU1GjR8OTT8Lx49qK9927V/qUQgghhLhO1Lsc7uuByZRcJNguicVivDQCfg3YsqXs5GhVhbNntXblcHZwpn1AewAOJx/GSe9U4e6oqkrqmlSOTjyKKU1bicrD4/KK9zJ5UgghhBAVIQG3qH3x8VXarlWDVnx0x0f8ePePdnVHURROPXeKhEUJJK+4/EfNgw9qzz/8ALm5dp1aCCGEENchSSkRta+Ka4C7OLrw1E1PVaJDEDQ5iOyD2bhHuBdu69sXQkMhNhZ++QXuvbdSlxBCCCHEdUJGuOux06dnkpj4E2Zzdm13pXJqowZ4ORpPaUzLeS3x6Hx5AqXU5BZCCCGEPewKuKdPn86bb75Z1X0RFZSWtobDh+9m27aG/PPPSC5c+JaCgou13a2KK6sGOGg53BWsAX724lm+2f8Nvxz9pWr6eIk14F67ViugIoQQQghRHrsC7k8++YQDBw5UdV9EBQUEPIDB0BSLJZfk5JUcOXI/27b5c+DAEOLjF2IypRRpbzTGFpYXLOlhNMbW0ifhcg3wxo2L79Pp4IaKLWu/MWYjD/z8AP/d8V+7u6RaVNK3phP7n8v/XZo10wbaLRatJrcQQgghRHnsyuEODg7GYrFUdV9EBQUHT6V168VkZe0nOXk5SUnLyck5QmrqKlJTV3Hs2KN4e/elYcPReHh0ISqqd5nVT6q11KAtSqoB/tZbsG4d/PvfsGCBzadq21BbMOhwkv0rdJqSTETdEgUWaDi6IS5NXQBt8uSWLVpaSXi4VrHwo4/g7rvtvpQQQgghrmF2jXCPGDGCTZs2kZmZWdX9EWiL2uh0hjLb6HQGHB39UBQFD4/OhIe/Sbduh+na9TBhYW/i7t4ZMJOe/hcnTjzO3r1d60epQWsN8LFjtWdr6tJXX8HJkzafpk3DNigoJOUkkZSdZFdXnAKc8LnVB4DEHy4v9X733eDqCseOwaRJkJAAjz4KiYmlnUkIIYQQ1zO7Au7XX3+d0NBQBg8ezL59+6q6T9c9gyGUbt2OERERWeqjtJFoN7c2hIW9TJcu+7jpppM0bfofPDxuqoVPUUW6d4fBg7XFcd54w+bDXB1dCfMOAyo3yu1/n7ZK5YXvLhRu8/CAESO019mX5qtmZsLjj9t9GSGEEEJcw+xKKRk2bBjOzs5s27aNLl26EBgYSGhoKAZD8VFZRVH466+/Kt3R643BEFrp1A4Xl2aEhv6L0NB/kZKyioMHh5R7jMVSBwtMz5oFq1bBt9/Ciy9C69Y2Hda2YVui06M5nHSYW8JusevSfiP8OD75ODmHcsg6mIV7B61MYFiYtl9VtWezGVasgGXLYMwYuy4lhBBCiGuUXQH3xo0bC1+rqkpcXBxxcXEltlVKK/UmapSTUyOb2kVF3YqPz200aDAEX9/BuLiEV3PPbNClCwwdCr/+qo1yf/edTYe1a9iOP078UakRbkdvRxoMbkDyz8kkfp+Iewd3EhPhk0+Kt1UUeOwxLRPG39/uSwohhBDiGmNXwB0dHV3V/RB1hKrmk5r6P1JT/weAq2ubS8H3ELy8eqLTORZpbzTGlpn37ejoVzWTMGfN0gLuH36Al16Cdu3KPcQ6cfJQ0qFKXdp/rH9hwB3273AmT1bIyireTlUvp5YsX16pSwohhBDiGmJXwN2kSZOq7oeoI9q2XYbRGE1KyiouXtxKTs4RcnKOcPbs++j1nvj6DsDXdwgNGgzCYslj165WNVP5pHNnGDVKi2Rffx1+LH/Z9v7N+rPqvlW0929fqUs3uLMBenc9xhgj+7/LYOVKr1LbWlNLDh2y6W8CIYQQQlwHZGl3UYSLSzP8/e8mNHQGJlM6aWlrSEnRygyaTEkkJf1EUtJPgDb6bWvlkyoZ5X79dS2a/ekn2L8fOnUqs3mQRxBBHkGVvqzeVY/fcD8uLLmA+85ERozw4tdfteC6WFu9VtlQgm0hhBBCWFUq4E5KSmLRokVs2bKFuLg4FEUhMDCQPn36MGHCBPwlkbXOsJYaLG802tHR74pjvPH3H4O//xhU1UJm5h5SUv4gNXUVmZl7yMk5UhNdv6x9e21G4tKlWvC9cmWNXdp/rD8Xllwg8cdE5u1txoYNOi5evDxpErQcbk9PmDevxrolhBBCiHrA7oB7+fLlPPzww2RmZqJeGXUAq1at4q233mLhwoWMHDmy0p0UlWctNWhvvrWi6PD07IanZzfCw2eRl5dAXNxnnDkzq9xrq2oJQ8H2eu01LZ3k558hMhIiIspsvuXMFv6K/oueIT3pG9rX7sv69PfBoYEDpgsmHA+l89lnvtx7b9E2qgqffSYTJoUQQghRlF11uPfs2cPYsWPJyspixIgRrFy5kn379rFv3z5+/vlnRo4cSVZWFmPHjmXPnj1V3WdhJ4MhFA+PG0t9VCTtw9m5EX5+Q21qu3//7Rw6dC/x8YvJy4svs225y8+Hu8F992mNX30VNm6E77/XnkvI8fjl2C/M2jSL34//bvNnK4nOUUfD0Q0BSPw+kTFjtFrcev3lNsOGSUlAIYQQQhRn1wj37NmzMZvN/Pjjj8VGsDt16sTQoUMLA+933nmHn376qUo6K+onszmDpKSlJCUtBcDNrRO+vgPx9b3jUuUTJ0ALtm2ahPninxi++06rzb1q1eWdwcEwZ462RPwl7RpqydSHk+0vDWgVMDaA+PnxJC5LJOPvDN5/ozkbNviSnq7tHzeu0pcQQgghxDXIrhHurVu30qNHjzLTRYYPH07Pnj3ZsmWL3Z0T14ZWrRbSpMkreHh0AxSys/dz9ux/2L//VrZu9eXgwaGcPz+XrKwo2yZhHt8NFkvxnefPw+jR2sTKS6ylAStTi9vKq7cX4e+E49LUhZyjOaS9F838z1Ss6z1FRVX6EkIIIYS4BtkVcF+8eJHQ0PLTD0JDQ7l48aI9lxDXEHf3ToSHv0FExE569EikTZvvCAh4AEfHACyWbFJSfuPEiSf4559htp3wvfdK3m6dSzBtWmF6SZuGbQCIy4wj3Zheqc+h6BQ8OnuQfVBbzz1zdya3e6cVTpJcv75SpxdCCCHENcqugLtRo0ZE2TCcFxUVRaNGtq1wKOofa+WTslxd+cTJyY+AgLG0afMVPXrEERGxj/Dw2Xh53QLoSz/RlRITS9+nqnD2LFz6ZsXT2ZNgz2AAjiRXrqqKqqpEvxJ9uZt6iH4lmr59tUB/925t4RshhBBCiCvZlcM9cOBAvvzyS1555RXeeOONYsu3q6rKK6+8wtGjR3nkkUeqpKOi7qmKyiceHp3x8OhMkyYvkJ6+maioW8q9bkpXcL4AThllNIq/PDmzbcO2nMs4x5HkIzTC/j8A09akkbn7iojarI1yhx9LIzzcl+ho2LoVBg2y+xJCCCGEuAbZFXC/8sorrFixgrfffpsffviBMWPGEBYWhqIoREdHs3TpUqKjo2nQoAEvv/xyVfdZ1CEGQ2jVLGoD6PXuNrWLeQRiHgb3E+C7W3t4HgLdlUVKAgMLX7byCWENsD9uE0G6LmRl7cPB4fKPvi3LzxcZ3b7yOpdGufv19SE6WmHDBgm4hRBCCFGUXQF3cHAw69evZ9y4cfzzzz/Mnj27cJTbWpO7Q4cOfPvttwQHB1ddb4UADPEOGAMLyGoFWa0g9n7QZ4P3PvDdA75nA3Hp3RvQKp/0clxC164Q5PI9euV79u8vej5blp8vNrptdWmUe1C/NBbiy4YNVflJhRBCCHEtsHvhmw4dOnDgwAE2btxYuNIkQFBQEL1796Zv375V1UchimjnOhun0f8iLQJSu0JaFzB5Q0ov7QHxGHa3wtd3IC4uzfF3ygOn0s9X3vLzhaPbOqCE4ijooPHqaMCHvXsV0tPB27uSH1IIIYQQ1wy7Au6RI0cSGBjIp59+St++fSW4FlXC5uXnB47B+fOmNJo6lUZrzqEqkNVCC75Tb3Elo2U+RuMp4uLmVkm/1HwVY6yx5GAbwAKWC0baNlc5fFJh82YYatuaQEIIIYS4DtgVcK9atYrhw4dXcVfE9a5CkzBHhmpLO27ZghIfj4dOh8eDD9Lk2xwKlnxO+sAAUlNXk5z8K/n55/j5PBzKgLEh0NS2VPFCOmcdEbsjMCWZALAUWMg7m4cpxYRnF0+tX/6O9P63jsMnYcMGCbiFEEIIcZldAXd4eDjZ2dlV3RchKjYJU6+HK79dOX0aXnwRh2dfwW/IUfxaDiUw8GEiIyPYmgyR6XCjT8kB97lzc2jU6AG8vHqh0zkX71eIAUOIVgIxLy6PfTftAz30MfZB56BV1+zXD+bPR/K4hRBCCFGEXXW4x44dy6ZNm0hISKjq/ghhv+nToWVLuHABXnutyK4mbtpzTCl/J1648DX799/O1q0+HDgwmHPn5pCdfbRwEvCVnBo5oTgBZkg9tpfMTO1x0017adFiLzk5e4mPj63iDyeEEEKI+squEe6ZM2eyc+dObrnlFt555x3uvPNOHB0dq7pvQlSMszN88gkMGKA9T5wITbVdTVy15zM5JR/q63snWVl7yM9PIDX1f6Sm/u/SKUPx9R2Aj89AfHxuw9HRh7z8s6gN4+B8EP+sexg6HSg8z+efa89Hjxrw8Sm78okQQgghrg92BdytWrXCYrFw9uxZRo8ejaIo+Pv7YzAUX3VQURROnTpV6Y4KYZP+/eHuu+HHH+GJJ+CPDwEIuxRwlzbCHR4+C3f3G8jOPkhq6hrS0laTnr6FvLxY4uO/JD7+S0CHp2c3XF07gn8rOB8EFwJKPJ+ilF35RAghhBDXD7sC7piYmCLvVVWV9BJRd3zwAaxaBdu24fjbZnShBpq4aZVPLuRBrhlcrlhF3rr8vKIouLt3xN29I6Ghz2E255Cevom0tDWkpq4mJ+cIGRk7yMjYAQEztINLCbiFEEIIIazsCrgtltLqowlRBwQHw6uvwvPPY5j+Dt0O7sLkasI/qj+JOak4N15MROMOhc1LW2lSr3elQYNBNGigLR1pNMaSmrqGxMSlpAdc0BqVEXCnpICHR9V+NCGEEELUP3ZNmvzoo4/48ssvq7ovQlSdadOgdWtISsIwax4ekRm0tQSgR0dSnhMeHjcWPmxN+zAYQgkKmkSzZu+CDQH38eOPExv7PllZB0qcfCmEEEKI64NdI9zPPvssgwcPZtKkSVXdHyGqhpMTfPop3HYbzJsH8+bxvTv45ILTF/+Cj5xh5Ej7z29DwO3ktIvTp3dx+vS/cHIKxMdnAL6+A/Hx6Y+Tk1+RtkZjrG31x4UQQghR79gVcDdq1KjECZJC1Cnp6UXeNsrSntW4OBg9Gn76yf6g2xpwJ/qDCijFm6xe/Sxjxx4mPX0j+fnxXLjwFRcufAUoeHhE4OMzEF/fgTg5BbFnT/tyV9js1k2qngghhBD1kV0pJQMHDmTr1q3k5+dXdX/qhPfff5927drRvn17lixZUtvdEfYwm2Hq1BJ3Kdb0jmnTtHb28E8ExQJ5Bkj3LrHJ8uX30aDBKnr2TKVjx7WEhDyHm1sHQCUzcw+xsW8RFdWHPXs6lRlsA1gsxjJHwIUQQghRd9kVcL/11lvo9XrGjRtHfHx8VfepVh08eJDvvvuOyMhI9uzZw7x580i/aqRU1ANbtsC5c0U25evh4aFw88OQ7aDC2bNauwpydPRD5+wADVK0DYn+xdqYTAYuXvRjwwbQ6w34+t5Os2bv0bXrAW6++TytWi3C338sDg4NsFhk1VYhhBDiWmb3wjedOnVixYoV/PHHH9x4442EhoaWWod7wYIFle5oTTly5Ag9evQo/CydO3fmzz//5N57763lnokKKeEPQScz/NoKkt3gmB/cGF9yu/IYDKF063aMg03PkJ1spqnb1/hEFF346f33/UhMDGX9erj//qLHOzsHERj4IIGBD6KqFi5c+I6jR8eXe92cnOO4u9+AopSQvyKEEEKIOsuugHvx4sWFr41GI9u3b2f79u0ltq3qgHvz5s289957REZGEh8fz8qVKxk+fHiRNnPnzuW9994jPj6edu3a8eGHH9K7d2+bzt++fXtmzZpVOKq9fv16mjZtWmX9FzUkMLDEzW2TYLMbHG54KeAupV15DIZQ3Jpmkb0rEf3FYDw8GhfZf/PN2vOGDWWfR1F0uLm1temaR46M5dSpZ66afNmw1PYyEVMIIYSoG+wKuDeUF0VUo+zsbDp16sRDDz3EqFGjiu1funQp06ZNY+7cufTs2ZP58+czaNAgDh8+TGioFlxERESQl5dX7Ng1a9bQtm1bnn76aW699Va8vLzo2rUrDg52/WcStal3b60e9/nzcEVJvnZJsDkMDvkDISFaOzs1/7g5rRa0Qu+qL7avVy9wcICYGO0RFmb3ZQopioH8/AQuXPiaCxe+5urJl56e3dHptJF2ozGWXbtayURMIYQQog6wK5K85ZZbqrofNhs0aBCDBg0qdf8HH3zAww8/XFiy8MMPP2T16tXMmzeP2bNnAxAZGVnmNR577DEee+wxACZNmkTz5s1LbZuXl1ckeM/IyADAZDJhMpls+1CiWij/93/o770XFKVwomTbJG3fYT8oeOR9VIsF7FzISfFSsGDBYip+vLMzdOmiZ8cOHevWFTBhQul1uAsKCmy6Xvv2a7FYckhPX01a2lpycg6SmbmncAKmXu+Jl1dffHy0yie2TMTMzU1Ar7dvlL8qWX9X5HembpL7U3fJvam75N7UbTV9X66podv8/HwiIyN54YUXimwfMGBAqSkvJUlMTMTf359jx46xa9cuPvvss1Lbzp49m1mzZhXbvmHDBlxdXW3vvKh6zs4EzphBhy+/xCVFm+BoDbj/CdTzh5OTtgR8NQkObgO05Ntv42nYcG+p7XS6UzatSLl9+y4slmZAH6APipKKg0MUDg77cHCIAjJITf2V1NRfbe7j1q1bsVjqzsTntWvX1nYXRBnk/tRdcm/qLrk3dVNOTk6NXq9SAXdycjJLlixh9+7dJCcnc9tttzFjxgwA/vnnH06fPs3tt99eY4FncnIyZrOZgICii5EEBASQkJBg83mGDx9Oeno6bm5uLFq0qMyUkpkzZzJ9+vTC9xkZGYSEhNCvXz8aNGhQ8Q8hqtbgwfD66xRs3Yr53DnyjuwC5hHtaebWnAwMd4+1+9SmZBMxL8VQkFpAmx/bFNtvMCj89BOcOBHMoEGNKG2uY15eLJGRL6GqpY9IK4qBfv2G4ex8dfqHNiNTVc1kZe0jPX0NaWlryMzcAZQ/ct+rVy/c3W8ot111M5lMrF27lv79++Po6Fj+AaJGyf2pu+Te1F1yb+q2lEsDcTXF7oD7hx9+4NFHHyU7OxtVVVEUhcaNL08cO3HiBKNHj2bx4sWMH19+BYaqdHUVB2v/bFWR0XBnZ2ecnZ2LbXd0dJRfsLrC0RFuvx3VZCLvD28aRC3GMz2XpHdfpumoe7T8Dzso7gqJixK113kKDu5Ff5369NEWvDx/XuHMGUdatCite8246aZjlZzg6Iiv7834+t4MvEZa2ib27+9b7mfIyFiPu3tzHB19y21bE+T3pm6T+1N3yb2pu+Te1E01fU/sCri3bNnC/fffj4+PD//+97/p2bMnXbt2LdLmzjvvxMvLixUrVtRYwO3n54dery82mp2YmFhs1FtcnxRFIeaJ07h3vAESzsLcufDMM3ady8HDgfDZ4TgHOqPoiv9B5+IC3bvD5s1atZLSAm7Qqp5U5eRFBwcbclSA6OiZREe/hKdnN3x978DHZyCenl1RlOITQUEqnwghhBD2sCvgnj17No6Ojqxbt45OnTqV2MbR0ZHWrVtz6NChSnWwIpycnIiIiGDt2rWMGDGicPvatWsZNmxYjfVD1G3O3g3gzTfhkUe05wkTwNe+Ed4mLzQpc3+/fpcD7kcftesS1cpgaIrReJqMjB1kZOwgJuZ1HBx88fHpj6+vVv3E2TkIkMonQgghhL3sCrh37NhB9+7dSw22rUJCQjh48KBdHStNVlYWJ0+eLHwfHR1NVFQUvr6+hIaGMn36dMaPH0+XLl24+eab+fzzz4mNjWXy5MlV2g9Rzz30EMyZA//8A//+N3zwQbVcpl8/mDVLC7hVlVLzuGtLu3Y/4ujYkNTU1aSlrSY1dS0FBakkJS0lKWkpAG5uHfD1vQODoanNS9BLwC2EEEJcZlfAnZuba9OEwIyMjCpfFW/Pnj3069ev8L11wuKECRNYvHgx99xzDykpKbzxxhvEx8fTvn17Vq1aRZMmZY9EiuvH0eSjPLn6SUwPmtn+HPDJJzBlCpRR/rE0efF5ZB/IxsHHAc9unsX2d+8OBgNcuABHjkBb29a4qTRHRz90OkO5o9FaCkgIQUGTCAqahMVSQGbmLlJT/yQ1dTWZmbvJzj5IdnbV/uEshBBCXE/sCribNGnCgQMHymxTUFDAgQMHyqxhbY++ffuiqqXXNAaYMmUKU6ZMqdLrimuHp7Mnm89sRqfoyLujP85/roWZM+HHHyt8rsTvEjn13Cn87/Wn7ffFo2lnZ+jZE/76SxvlrqmA27r8fEXzrXU6B7y8euDl1YPw8DfIz08mLW0dqal/kpLyOwUFNTurWwghhLgW6Ow56M477+TUqVN8+umnpbb54IMPSEhIKJJLLURdEOgeiJezFxbVwvGXHgOdDn76CbZtq/C5nJtoFU6MZ0ofSbZ+IVPTC7QaDKF4eNxY6sOWtA8nJz8CAu6lTZvFdOy42qbrJiR8RVbWwXL/MBZCCCGuF3YF3C+88AKBgYE8/fTTjB8/np9++gnQqoH8/vvvTJo0iRdffJHQ0FCefvrpKu2wEJWlKAptG2pDzYe8TTBxorbj2WeLLANvC0MTAwDG2PID7o0b7V7Usk6wNT3s/PmP2LOnI3//HczRoxNJTFyGyZRaYlujMZbMzL1kZe1DpztFVtY+MjP3Fj6Mxtiq/AhCCCFErbArpcTPz49169Zx99138+233/Ldd98B8L///Y///e9/qKpK69atWblyJV5eXlXaYSGqQruG7fj73N8cTjoMb7wB338PO3fCa69BmzYQGAi9e4O+5PJ4VtaAOz8uH0u+BZ1T8b9hu3YFNzdISYGDB6Gcucb1nqdnT7Ky9pKfH0dCwiISEhYBOjw9b8LX9w58fe/AwyOCvLzzRaqeeHjA/v1FzyVVT4QQQlwL7F74pnXr1uzfv59ff/2VdevWERMTg9lsJjg4mNtvv53Ro0ejLydYEaK2WEe4Dycdhn6BcOedsHSpVibQKjhYq2QycmSp53Fs6IjOoMNitJB3Lg+Xpi7F2zhqsfuff2ppJdd6wN2ixUe4urbl4sWtlyZf/klOziEyMv4mI+NvYmJew8HBFw+PLlL1RAghxHWhUku763Q6hg8fzvDhw6uoO0LUjCIB94oVsGxZ8Ubnz8Po0Vp+dylBt6IoOIc6k3s8F+MZY4kBN2hpJdaAe9q0qvoUNasilU/0egO+vrfj63s78D5G41lSU1eTmvonaWla6cG0tDU113khhBCiFlUq4Baivmrn344gjyDCvJqgTn0apaTcbWvh7GnTYNiwUtNLDE0MhQF3aax53Js2gdlcbqZKnWRv5RPt2CtLD5rIyNh5Kd1kYXV2WQghhKgTJOAW16Vgz2DOTz+vzWQ816/0hqoKZ8/Cli3Qt2+JTax53Hln8ko9zQ03gKcnXLwIUVEQEWF/32tTVSxBr9M54u3dC73e1aaA+9ChUfj5jcDX9w68vPqg1xsqdX0hhBCipknALa5v8fGVbmdLaUAHB+jTB37/Hdavr78Bd20wGmM4d+6/nDv3X3Q6F7y9+xVOvnRxaV6seorRGGvXKLwQQghRXSTgFte3wEAKdOBQXrm+wMBSdxlCL5UGLCPgBrj1Vi3g3rAB/vWvinb0+hUe/i65ucdITf2T/Pw4UlNXkZq6CgCDoeml4HsQPj79MJlSilQ+KYlUPhFCCFHTJOAW160fD/3IM3ufoef9Liz9xlh6De6QEK3MSCkKa3GXE3Bb87i3bAGTSateIsrn63s7Hh4zUFWV7Ox/CiufXLy4BaPxNHFxc4mLm4uiOOHm1kkqnwghhKhzJOAW1y13J3fOZ57nUJsQ4Jw2QbKkoPv998uc5WhNKck7m4dqUVF0JS8Q07Ej+PpCaipERkL37lXxKeqvilQ9Aa0ijLt7B9zdOxAa+i8KCjJJT99wKQD/H0ZjDFlZu2uq+0IIIYTNbFppsmnTpjz//POF77/++mu2b99ebZ0SoiZYSwMeNyVg+vEHaNy4aAPdpV+P2LJXO3Ru7Ax6cPB0wJRqKrWdTge33KK9Xr/e7m5fM6xVTyIiIunUaSeZmf9Hp047iYiILHyUlfrh4OCBn99QWracy003naZbt2MEBz9r07Vl2XkhhBA1yaaAOyYmhqSkpML3Dz74IF9++WW1dUqImhDqFYq7kzsmi4lTt3SEmBgtwfq777Tnzz/XGr75Jly4UOp5dI46emf2pmdST5z8nMq8pjWtZMOGKvoQ9ZzBEIqHx424u9+AxdIMd/cb8PC4sfBha9qHoii4urYkIOA+m9ofODCQo0cfurTsfFplPoIQQghRLptSSlxcXEhPT6/mrghRsxRFoY1fG3bH7eZw0mFa+7UuWvqvTx+YN0/L/3j5Zfjii1LPpXexrbD2rbdqz9u2QV4eODtX4gMIuxUUpJCQsJiEhMVoy853L5x86eFxI4pSdCxCKp8IIYSoDJsC7tatW7N27Vq++uorwsPDAUhISGDz5s02XaRPnz7291CIatS2YVt2x+3mUOIhRra5ajVJnU5b2r1XL1iwAKZM0QpqV+Z6bcHfHxITYdeuMudiimrUosU8cnNPXrHs/HYyMrYTE/Mqjo4N8fUdeKnyyQAslhypfCKEEKJSbAq4n3vuOcaPH8/EiRMLt61evZrVq1fbdBGz2Wxf74SoZoVLvCcfLrlBz55w773www/aipMbN2qTK6+StDKJuLlxePXxIuyVsFKvpyjaIPqyZVpaiQTctcPTsxuNG09GW3Y+trDySVraOkymJC5cWMKFC0sABVfXtlL5RAghRKXYFHCPHTuWFi1a8Ntvv3H27FkWL15Ms2bN6NmzZ3X3T4hqdWPgjfQO7U0H/w6lN3r3XfjlF9i8GX76Ce6+u1gTU6KJtHVpKM4lVyi5Ur9+WsC9fj28+mplei+uVtHKJ6DlkQcFPUpQ0KNYLPlcvLi9sPJJdvYBcnIO1UTXhRBCXMNsLgvYpUsXunTpAsDixYvp1asXCxeWvyyzEHXZ7U1v5/amt5fdKDQUZsyAWbO0FWvuvBNcXIo08b7Nm1aLWuHWzq3ca1onTv79N+TmFjuVqARr5RN78611Oid8fPri49OXZs3eIS8vjri4+Zw580a511ZV+SZPCCFEyeyqw71o0SKaN29e1X0Rou6aMUPL4z5zBv7v/7RJlFdwbe6Ka3NXm07VsiUEBUFcnBZ0WydSiqphMIRWWWqHs3MQfn7DbAq49++/DV/fwTRoMAhf3ztwcgoota1MwhRCiOuLXQH3hAkTqrofQtSqHFMOJrMJL4NXyQ1cXeE//4H77oPZs+Ghh4rX7baRomij3N9+q+VxS8B9bTCbM0lKWkpS0lIA3N1vxNd3EA0aDMLD4yZ0Ou2fW6MxViZhCiHEdcamOtyl+eeff5gyZQodOnSgQYMG+Pn50aFDB5544gn++eefquqjENXqmT+fwf1tdz7d/WnZDe+9F3r0gJwceP55bQLl999rz2Yz6ZvSifsijry4vHKvKfW4rz2tWi2kSZOXcXePACAray+xsW+xb18vtm9vyKFD9xAfv5js7CM2T8IUQghxbbB7afc5c+bwr3/9C7PZXGTVttTUVA4dOsQXX3zBe++9x9SpU6uko0JUlwD3AFRUDieVUqnESlG0MoFdu2rD099+e3lfcDAnnRaRddqB9r+0x3lo2QW2rQH3zp2QlQXu7pX8EKLWubt3IjDwIcLD3yQ//wKpqatJTf0fqalrKChIJSlpGUlJy2q7m0IIIWqBXSPca9eu5ZlnnsHJyYlnnnmGffv2kZaWRnp6OlFRUTz77LM4Ozszffp0/vrrr6rusxBVyloa8Jdjv7Anbk/ZjUtb5v38eQyn/wbAeKbs0UuA8HBtLmZBgbYIjqi7rJVPynJ15RMnpwAaNXqAtm2/p2fPRG64YTtNmryCh0eX6u6uEEKIOsiuEe4PPvgABwcH1qxZQ48ePYrs69ixI++99x4jR46kT58+/N///R+33XZblXRWiOpgDbiz8rP4ev/XdAkqJSgym6G0b2xUFQPa8u/G6Nxyr6koWu724sVaWsnAgfb0XNSEylY+URQ9Xl434+V1M+Hhb5Cauo4DB/qXe93MzH24uXUszP0WQghRf9n1L/muXbu45ZZbigXbV7r55pvp27cvO3futLtzQlSnM+lnSM5JxqJaCrd9d/A7Huz8IKqq4ufqRxPvJpcP2LIFzp0r9XzOJACQt/c80KLc6/frdzngFnVbVVY+cXT0tand8eOTOH36OXx8BuDrq1U+cXZuVGp7qXwihBB1l10Bd05ODg0bNiy3XcOGDcnJybHnEkJUu7A5YcW2peSmEPF5ROF79bXL8xOIjy/zfIUj3Ofybbq+NY97zx64eBG8SimQIq5Per0nBQXpRXK/L1c+GYyn500oih6QyidCCFHX2ZXDHRISwt9//13mku0FBQX8/fffhISE2N05IarTkhFLcCjl63oHnQNLRiwpujEwsMzzFQbcqU42XT8kBJo1A4tFGzwX4kqdOq3jhhv+LpL7fbnySU+2bWvIoUP3kpDwNTk5x6TyiRBC1GF2BdzDhg3jzJkzTJo0iYyMjGL7MzIyeOSRR4iNjWX48OGV7aMQ1WJcx3HsnFRyytPOSTsZ13Fc0Y29e0NwsJaAXQIDiQCY0sBstG3VQSkPeP2xdRKmk1MAXl7dCQ9/g4iI3fTokUDr1l/h738vDg4+FBSkkZS0lKNHJ3DgwIAa6r0QQgh72JVSMnPmTFasWMHXX3/Nzz//zODBgwkLC0NRFKKjo/njjz/IyMigadOmzJw5s6r7LESV06HDgqXwuUR6vVYWcPRoLei+ohwmgAMX0RlULEaFvNg8XFuWv/LkrbfCl19KwH09sXcSprXySaNGD2CxFJCZuYvU1P+RkrKKrKy91d1tIYQQlWBXwO3r68uWLVt47LHH+OOPP/j++++LtRkyZAjz58/Hx8en0p0Uorr4u/nTyL0RIZ4hPHzDwyzYt4CzGWfxd/Mv+YCRI+Gnn7RqJVdNoFRatsTg4EbO4RyMsUabAu6+fbXnqChITQVf2+bTiXquspMwdToHvLx64OXVg/DwN0lJWcPBg+WXusnOPoS7e2cUpVJrngkhhKggu+tNBQUF8dtvvxEdHc3WrVuJi4sr3N6rVy/Cw8OrrJNCVJdgz2BipsbgpHfCZDHRI6QHge6B+Ln5lX7QyJEwbJiWeB0fD46OMGECHD+OoVMqORjIO1P+apOgpYW3bg1Hj8KmTTBiRBV9MHFdcXIq4+f1CkePPsCpU8/i63sHvr6D8fUdUGbVFGvlk4KCAnS6U2Rl7cPB4fL/NqTyiRBC2KbSBV7Dw8MluBb1mrODtipkty+6sf/Cflbdt4pBLQaVfZBef3l4GuDYMXj5ZZxPbgdutWnxG6t+/bSAe8MGCbhF9dLpXDGZkrhw4RsuXPgG0OHp2Z0GDQbj6zv40ui3Nkfh6sonHh6wf//V55PKJ0IIYQv5XlGIS1r5tQIof4n3kkyfDqGhGLJPAbatNmklEydFTenUaQOdO28kJGQGbm7tAQsZGduJjn6ZyMgb+fvvII4enUhi4k8YjdFS+UQIIaqILGEmxCVt/bQVJ+0KuF1c4N13MYz9Ups8aba9qLZ1oPyffyApCWwocS9EEdbKJ+XV4XZ2boTBEIq39y00a/YuRuPZwomXaWnryM9PICFhEQkJiwB9zX0AIYS4xknALcQl1iXeDyfbEXAD3HMP/nM+ImDHcHCYACy26bCGDaFDBzh4EDZuhLvvtu/y4vplb+UTgyGEoKBHCQp6FIslj4sXt5KSsorU1FXk5Byt7m4LIcR1Q1JKhLikMOBOOox6Vck/mygKypwPtddffaUtIWkja1rJ+vUVv6wQoAXdHh43lvooL89ap3PGx+c2mjf/P7p1O0L79r/adF2jMca+3xchhLiOXNcB94gRI/Dx8WH06NEV2ieuTS0atECv6MnIyyAuM86+k3TrBvffr71+5plitbpLI3ncoq5xdm5sU7tDh0axc2cLTpx4mpSUPzGbc0ttazTGkpm5t9SH0RhbVd0XQog65boOuJ9++mm+/vrrCu8T1yYnvRMtGrQA4FDSIbvPc8Q4jZ3KN1zcmqLV7LbBLbdoa+kcOwb+/vDjj3ZfXoga5oDReIrz5z/m4MFBbNvWgAMH7uT8+Xnk5sYUtrJWPYmMjCj1sWtXKwm6hRDXpOs6h7tfv35s3LixwvvEteuxiMfIzs8m3Nv+UpfGJB25ajBGgvB67jnw8oKUFK3odu/eWknBq/j4QPv2Wh53UhI8+qgWhPuXsv6OEHVF584bKChIKcz9zss7R2rqH6Sm/gGAq2tbGjQYjMHQ3OaqJ1JmUAhxramzI9ybN2/mrrvuIigoCEVR+Pnnn4u1mTt3LuHh4RgMBiIiItiyZUvNd1RcU6Z1n8ZLfV4qHOm2R/i/w+m0qjW+PichNhYGDoT77tPyRsLCYMWKYseoKuRe8U18ZiY8/rjdXRCi0qyVT8qi0xkwGELx8xtGq1bz6d49li5dDhAePhsvr96Anpycw5w9+z4nTkyumY4LIUQdZNcId9OmTW1q5+TkRIMGDejcuTP33XcfPXv2tPka2dnZdOrUiYceeohRo0YV27906VKmTZvG3Llz6dmzJ/Pnz2fQoEEcPnyY0FBtdCQiIoK8vOIr/q1Zs4agoCCb+yJERXj38taC6rQzxXeePw+jR2upJiNHFm5etgxOnrzczGzWTrFsGYwZU/19FuJqV1Y+KSgoYOvWrfTq1avMlSYVRcHdvQPu7h1o0uQFTKY00tLWkpKyipSUXykoSKuNjyKEELXOroA7JiamQu3//vtvPvvsMx5//HE++eQTm44ZNGgQgwaVvtrfBx98wMMPP8ykSZMA+PDDD1m9ejXz5s1j9uzZAERGRlaon/bIy8srEtRnZGQAYDKZMJlM1X59YTvr/SjrvlhUC6fSTnEs5RhDmg8pXHWvQsxmHJ5+GoBiR6sqqqLA1KkUDB4Mej2JifDYYw4oCqjq5SMUReWxx6Bnz4JrPrXElnsjap5eH4heH4jJZMJiicfZuT2Ojo5F2pR9z9zx8RmBj88IAgImc+DAzeVeMynpD/T6xmUuOS8uk9+dukvuTd1W0/fFroDbYrEwbdo0vvnmG5566inuvvvuwlHl2NhYfvzxRz755BPGjRvHjBkz2Lp1KzNmzGDevHl0796d+61VHOyUn59PZGQkL7zwQpHtAwYMYPv27ZU6d0XNnj2bWbNmFdu+YcMGXF1da7QvwjZr164tdV+eJY+xB8ZiwcKidovwcfSp8Pl9dx6h2flOWLiJYIqnjyiqCufOsfP990lu34F33+1KZmYjVLVohpeqKmRkWBg9OokXXthd4X7UR2XdG1H7KnN/dLpTeHiU3y429lXOnHkds7kVBQU3YjJ1wWIJo4Q/XwFQlCQUJaPU86mqJ6p67a8mJb87dZfcm7opJyenRq9nV8D98ccfM3/+fHbv3k379u2L7GvXrh3t2rVj9OjRdO3alaZNmzJ16lTatm3LjTfeyIIFCyodcCcnJ2M2mwkICCiyPSAggISEBJvPM3DgQPbu3Ut2djbBwcGsXLmSrl27lrvvSjNnzmT69OmF7zMyMggJCaFfv340aNDAzk8oqoPJZGLt2rX079+/2CjdlZqebcrJtJMEdQqiX1i/Cl/HeDyHSLqjI5fGrCglTIDuTZpwsMlgduwovS8Wi44dO4Jo0mQw7dpVuCv1hq33RtSOqrg/WVn72L+//HYGQ1OMxtM4OBzBweEIBsO3ODk1xsfnDnx8BuHtfSt6vTsAeXmxREa2R1VLn4ypKAYiIv7B2fnanIgpvzt1l9ybui0lJaVGr2dXwP3ZZ59x6623Fgu2r9S+fXtuvfVW5s+fz9SpU+nQoQNdunRhvy3/4tro6q/7VVWtUArA6tWr7dp3JWdnZ5ydnYttd3R0lF+wOqq8e9PWvy0n005yPO04A1oMqPD5dZ0CAbDgQgGeOFLy6JtDSAidOzsyYgT8+quWt301vR6GDYPOna+PnyX5vanbKnN/rsz9Lku7dj/i6OhXWPUkLe0v8vPPc+HCAi5cWICiOOHtfQu+voMxGMLKDLYBVNWIql685n+u5Hen7pJ7UzfV9D2xq0pJdHQ07u7u5bZzd3cnOjq68H1YWFiVDOH7+fmh1+uLjWYnJiYWG/UWoqLaNdSGkg8n2bfEu/623jjq0gEwUsLPo6JASAj07o2iwGefgYeHtvnqZp6eMG+eXd0Qok6xteqJdSJm48aT6dDhV3r2TKFjxz9p3PgpDIamqGo+aWlrOXXqGQ4dGlFDvRdCiMqxa4Tbz8+PTZs2kZ2djZubW4ltsrKy2LhxIw0bXs6dS0tLw8en4jmxV3NyciIiIoK1a9cyYsTlf3DXrl3LsGHDKn1+cX27col3u+j1GJq5YzoBRhrhwYmi+1UVPvywsB63v78WdN97b/Fmn30mtbjFteHKqielubrqCYBeb8DXdyC+vgNp3nwOubnHSUn5g5SUVaSnbwIKqrnnQghReXaNcI8ZM4bExETuuOMOdu8uPplr9+7dDB48mOTkZMZcqmmmqioHDx6kZcuWNl0jKyuLqKgooqKiAG1UPSoqithYbRWy6dOn8+WXX7Jw4UKOHDnCM888Q2xsLJMnS61XUTmVDrgBQ2ctrcToVcLPu4sL9OpVZNOYMTBiRNE1cRo3lpKA4tpiMITi4XFjqY/yFrxRFAVX11aEhEync+d1dO78l03Xzco6gKqWkLMlhBA1xK4R7lmzZrFlyxa2bdtG9+7dCQ4OJiQkBEVRiI2N5dy5c6iqSpcuXXj99dcBOHDgAJ6entx79TBeKfbs2UO/fpcnrFknJk6YMIHFixdzzz33kJKSwhtvvEF8fDzt27dn1apVNGnSxJ6PJESh1n6tUVBIykkiKTuJhm4Vr3BgaKJ9dZ43YQaMuB/i4yEgAJ57Dvbtg1df1YavL7GmlmzYAOnp2racHLBYQFdnl6cSonZZJ0+W59ixhzh9+l/4+t6Br+8QfH0H4lhGBSKjMbbCI/FCCFEWuwJuNzc3Nm/ezHvvvcfnn3/O2bNnOXv2bOH+oKAgHnvsMf71r39hMGiBR6dOnThy5IjN1+jbty+qqpbZZsqUKUyZMsWejyBEqVwdXXmv/3sEewbj4uhi1zmcm2gTaY1n86Fv38s75syBPn3giy/giSegQ4fCXf7+MH8+PP20FnSnpWlLvXfqVIkPI4RAp3PHZErmwoUlXLiwBNDj5dWDBg2G4Os7BDe3doUT7o3GWHbtalXmMvQ6nYFu3Y5J0C2EsJldATdo1TlefvllXn75Zc6ePUtcXBwAgYGBhTW5haivnu3xbKWON4Rqf2gaz1z1P+3eveHuu+HHH+GZZ2Dt2iKzJceM0R6DB8P//gd//SUBtxCV1anTX6hq7qXc7z/IyTnMxYtbuHhxC6dPv4CzcygNGgyhQYMhODj4lBlsA1gsRkymZAm4hRA2q5Ivq0NCQrjpppu46aabJNgWgitSSmLziu98911wctKi6d9/L/H4W2/Vntevr64eClH/2Vr5xNm5Ed7et9Cs2X/o1u0QN90UTYsWn+DrOwhFcSYvL5a4uHkcPHgnUVEVr70vhBDlsXuE2yo+Pp7t27cTFxeHoigEBgbSo0cPAgMDq6J/QtSKjLwMtsVuIzM/kzHtKj5z0ZpSYko2Yc42o3e7YjZkeDhMnw7vvAPPPgsDB2oB+BVuu0173rQJTCaQEq5CFGdv5RMXlzAaN36Cxo2fwGzOIS1tPamp2uh3Xt7ZUs4khBD2szvgTkpK4qmnnmL58uVYLJYi+3Q6HaNGjeLjjz8uUhZQiPriaPJRBn83mEbujewKuB29HdF76jFnmDHGGnFrc1X5zJkzYdEiOHEC5s6FadOK7O7UCXx9ITUV9uyBm2+uxIcR4hpmMIRWKrVDr3fFz+9O/PzuRFVVEhOXceRI+ZP7Cwou2n1NIcT1x66A++LFi/Tp04djx47h4uLCgAEDCAsLA+DMmTOsWbOGZcuWsX//fnbs2IGXl1dV9lmIatfGrw0ACVkJpOam4uviW+FzGJoYyD6YjfFMCQG3pyf8+9/wyCMwaxbcfz/4+RXu1umgXz9YvlzLPJGAW4jqp5UdbGFT2/37b8PLqye+vkNo0ODOIhMvryZVT4QQdgXc77zzDseOHePuu+/mk08+KTaKnZyczJNPPsmyZct49913efvtt6uks0LUFA9nD0I8QzibcZYjSUfoGdqzwudw7+yO4qiU+j9hHnoIPvkE9u+H11/XXl/h1lu1gHv9enj5ZTs+hBCiGqlcvLiVixe3Eh0989LEyztp0GAI3t790Ou1CkdS9UQIAXZOmly5ciUhISEsWbKkxJQRPz8/vvnmG0JCQli+fHmlOylEbajsAjhtvm5Dl8gu+A4sZXRcr4f//ld7PW8eLF4M338PGzeC2VyYx719O+Tm2tUFIUQ16dDhd1q0+BRf38HodIZLEy/ncvDgELZta8DBg0OJi5tPdvYhm6ueCCGuXXYF3GfOnKFnz/9v787joqz2B45/nhlg2BFZREBRct8VNdcUl8xcupJlaWmlqVnm0q1s8Vbe0pb7M61ulnVvVrZopqblTU1RMRUUxdxXBFFc2GSHAZ7fH4+MItsAAwz6fb9e85qZ85znPGc8r8Evh/N8T29sy7iTy9bWlt69e5t2hhSirrHEjpPlCg6G7t21HW6efBLGjtXKmjShxeHV+PpCTo4WdAshqp+5mU+cnNrj5zeNDh1+o3fvRNq1W0/DhlMwGPwpKMgiMXE9J09O5dCh+2uo50IIa1apJSUODg4kJJT/23hCQgIODpXbOESI2mYKuBOqMeBevRr27i1efuECykOjGdD3HMsvNmbr1huZS4QQ1acymU9uvfEyI+MQiYm/kpj4G6mp8tuyEKKSM9xBQUFs376dyMjIUutERkaybds2unbtWunOCVGbCgPuY1fN3yH1ZhnHMwhvFU54q/CSK+Tnw4wZUNKOqtfLBh5eBGg3Tgohaoa9fWNcXLqU+ihrrbWiKDg7dyAg4FW6dPmTDh3+MOua2dkxluq+EMIKVSrgnjVrFkajkYEDB/LWW29x6tQpcnNzyc3N5dSpU7z55psMGjSI/Px8Zs2aZek+C1Ej2nu35+u/fc2aMWsqdb6Nmw1ZJ7LIOpVFgbGgeIWwMIiLK70BVWVA0ipAmwS/JlnIhKhzbG3dzap35EgI4eEtOH16NsnJWykoyK3mngkhalKllpTcf//9vPPOO8ydO5d58+Yxb948UyYG9frMnKIovP322wwdOtRyvRWiBrkYXBjfcXylz7drYEfHLR2xD7BH0ZeQqSQ+vtw2GnOeZg3SOH3ZhR07YMSISndHCGHVbMjKOkVc3IfExX2IXu9K/fpD8PAYTv36Q7GzK5qgoDDVYF5eHjrdGdLTD2Bjc+O/dEk1KIR1qfTGN6+88gqDBw/m448/ZufOnVy8eBEAX19f+vbty7PPPku3bt0s1lEh6hpFp+A+oIzZLTN3Yx3QLY3Tv7qwdasE3ELcrjp12orReNW09ttovMLVqz9x9epPgIKra4/raQeHo9e7sXdvK1P2ExcXLbvozSTVoBDWpUpbu3ft2pWvv/7aUn0RwuqcSDjB5rOb8XXxJaR1iGUb79sX/P3hwoWS13ErCvj7M3CcD0t/1fJxCyHqlsKsJ+Xl4ba3D6Bevb54eYWgqgWkpe27HnyvJz09itTU3aSm7iY6+jVsbRuYnWpQAm4hrEOVAm4hbneh50KZ/r/p3N/8/koF3ClhKSRvTsalqwueIz2LHtTrYfFiGD1aC65vDbpVFRYtIrivdqvFX3/BlSvg7V3ZTyOEqGmVyXqiKDpcXbvj6tqdpk3nkZ0dR1LSbyQm/kpy8h8YjZdroutCCAuq1E2TQtwpqpqLO2VrCjH/jCFxfWLJFUJCYNUq8PMr+bizM15e0KGD9nbbtkp1QwhRi6qS9UQ73x9f3ym0b7+e3r0TadZskVnXVdUSbtYWQtQKs2a4AwMDK30BRVE4c+ZMpc8XojYVBtznUs6RkZuBk51Thc43BBgAyI4p48+/ISHwwANa1pL4eG1t95o18NFHMHs2REUxYIANf/2lpQd8+OFKfxwhRB2n1zvi5tbXrLp//XUfXl6j8PAYjrv7IPT6iv38EkJYjlkB97lz56q5G0JYJ09HT7wcvbiaeZXjCccJ8g2q0Pn2AdqOdWUG3KAtL+nf/8b7jh1h+XI4cgS+/JIBA6ayaJGs4xZCmC8vL5H4+C+Jj/8SRTHg7j4AD48ReHgMx96+UbH6hZlPSiOZT4SoPLMC7oIC+bOUuHO18WrD9pjtHL16tNIBd05sDqqqmtJnlsvdHd56C6ZPh7lz6Rf5CHp9PU6fhthYaCz/5wkhytGs2SdkZZ0gMXE92dnnSEr6H0lJ/+PUqWk4OXXE01MLvl1cupGTE0dERMtyb+6UzCdCVI6s4RaiHFVZx23wN4ACBdkFGK8YK3bylCnQujUkJOD60dsUbtoqs9xCCHO4ufWkefOPuPvus3TrdpimTRfg6tob0JGRcZCYmLfZv78Hu3Y15NSp58zOfCKEqDgJuIUohyngTqh4wK2z02HnaweYsazkVra2sHCh9vqjjxjYOQmQgFuIO11hqsGy6HT22NpqmZEURcHJqS0BAXPo0mUnvXpdplWrb/Dyegi93gWj8QqJietroutC3LEkLaAQ5RjVahRdGnYxBd4VZd/YntwLuWTHZuPa3bViJ993HwwdCv/7HwMOLWI+89iyRcsYaO7qFCHE7eXmVIN5eXns3LmTPn36mL3TpJ2dJz4+j+Pj8zgFBblcuxZGfPx/uXLl+5r6CELccWSGW4hy+Ln60atRL+rZ16vU+aZ13DE5levA//0f6PX0+vMDDLb5XLwIJ09WrikhxO2hMNWgs3NnCgruwtm5c4VSDRbS6exwdx9Io0YvmFX/3Lk3uXp1DXl56VXpvhB3HJnhFqKamZUasCytW8Mzz+DwySf0sosk1NidLVugZUsLdlIIIcyQmLiexMT117OeBOPhMVKynghhBgm4hTDD+hPr2Rq9lZEtRxLcNLhC55qdGrAsb74Jy5czIGUdoXRn64qrTHP/Q8vZ3bevllZQCCGqmZfXo6SlhZOdfZakpN9JSvqdU6em4ezc6XrKwRG4uARJ1hMhbiFLSoQww/qT61kUvogt0VsqfG5hwJ20MYmkP5Iq1wEPD3jjDQaiXT90h46CseMgOBiaNIHVqyvXrhBCVEDjxn/n7rtP063bketZT3oBCunpUcTE/JP9+7uze7cfp0/PkKwnQtxEAm4hzNDWqy1QydSAjbUlJWqOSvSr0aiqWrlO+PrSlX04k0YSHhyko1Z+4QKMHi1BtxCi0iqS+UTLetLmetaTP69nPVmGp+eD6PXO5OZeIiFhbc10XIg6QpaUCGGGquTizjqdZXqdtjeN5E3J1B9Sv2KN5OfDCy9gSx792M5vDGcrA+hM1I2UJTNnalvEy/ISIUQF3Zz5pDSlrbm2s/PCx2cCPj4TKCjIISVlO/Hx/+Hq1ZXV2WUh6hSZ4RbCDIUB9+mk0+TkmZ9tRFVVYufHQmEMrIfouZWY5Q4Lg7g4AAagJeLewsCbLwTnz2v1hBCiEgozn5T2MGettU5noH79e2nc+GWzrhkT8y6Jib9TUFDJLE5C1BEywy2EGXxdfHE1uJKak8qppFO0825n1nnJm5JJ25t2oyC/krPc8fGml4XruHdwD0ZssCWvxHpCCGHtEhJ+IiHhJ/R6Z9zdh+DpOYL69YdhZ+dZYn3JfCLqKgm4hTCDoii08WrDnrg9HL161KyAW1VVoudGa7Pb+TcduD7L7X6vO4q5u9c0bGh62Z5DeJBAIp5E0J3e7CqxnhBCWDtPzxBSU3eTmxtPQsLPJCT8DOhwc+t1PevJSBwdW6IoCtnZsZL5RNRZsqRECDO18dSWlZxKPGVWfdPsdv4tB26a5TZb377g7w+Kgg6VYEIB2MoA7biiQKNGWj0hhKgjAgJeo2fPOLp02UtAwD9wdu4EFHDt2k7Onn2ZvXtbExHRgtOnXyApaaNkPhF1lgTcQpjpreC3uPz3y7za99Vy65pmt0v7hukquJZbr4fFi7XXimJaVlJkHfeiRXLDpBDCKlQs64kOV9euNG36Fl27HqBHjxiaN/837u5DUBQ7srJOExe3kJMnJ9dQ74WwPFlSIoSZ/F39za6r5qpkx2ZDQSkVCiD7fDZqropiMHNZSUgIrFoFM2YwIE67cXI3PcnEAceQ+7XjQghhBaqS9cTevjF+ftPw85tGXl4aycmbSEhYR0LCL+TnX6vObgtRbSTgFqIa6Aw6gvYGYbxqLLWOrbctOkMF/8gUEgIPPEDzHWH4j84gLsmJXfRi0K+/QkwMBARUsedCCGEZ9vaNq7yW2sbGBS+vB/HyepDU1L3s39+93HMyMo7i7NzZ/HtkhKgBsqREiAp4a9tbjPhhBKeTTpdb176RPS5dXEp92PuX/efWUun1KMH9GTDcCYAtAU9BTg68bF4aLiGEqIsUxbwlc8ePP87u3f6cPPkMiYn/Iz+/7HXfQtQECbiFqIDfTv3Gryd/5a/Lf1X43CsrrnDs8WNcXXPVIn0ZeH359laXv4FOBytWwJ9/WqRtIYSoqxTFntzci1y8+BmHDt3Prl1eHD48mkuXviE3t/gSl+zsWNLS9pf6yM6OrYVPIW43d/SSklGjRrFt2zYGDhzIqlWrTOVpaWkMGDAAo9FIfn4+zz//PE8//XQt9lRYizZebdh7cS9Hrx4lpHXF1kyn7knl8vLL2Hra4jXKq8p9CQ7WnvcddSTlseeo981H2m6T4eFaAC6EEHegTp22kpeXQmLiOhIS1pGbe/GWlIN98PQciYfHSHQ6g6QaFDXijv5f+fnnn+ebb74pVu7o6Mj27duJiooiPDycBQsWkJiYWAs9FNamKlu8O7ZyBCDzRKZF+tKoETRvDgUFsGPgW+DiAvv2wfLlFmlfCCGsibmZTwwGPzw8htKixZKbUg7OxcmpI1rKwR2cOfN3IiJaEBXVT1INihpxR89wBwcHs23btmLler0eR0ctOMrOziY/P7/iW3GL21JVAm6Hlg6A5QJu0JaVnDoFW/fXY+Trr2vruF95Rbu50tnZYtcRQojaVpnMJ4qi4Ora9XrawXlkZZ0jMXE9iYnrSEnZRnb2uRrouRBWPMO9Y8cORowYga+vL4qisHbt2mJ1Pv30U5o2bYq9vT1BQUGEhYVZ7PopKSl07NgRf39/XnrpJTw9S95mVtxZWnu2BuB4wnHyC27d0aZsji2v/xJ3LpuCnNLyBVbMgOv73mzZAsyYAYGBcPEivP++RdoXQghrYm/fGBeXLqU+ylv24eDQBH//6XTsuJnevRNo0mR+DfVc3OmsNuDOyMigY8eOfPLJJyUeX7FiBTNnzuS1117jwIED9O3bl6FDhxIbe+PmhqCgINq1a1fscfHixXKvX69ePQ4ePEh0dDTff/89ly9ftthnE3VXk3pNsLexJyc/h+iU6Aqda+djh95VDwWQdTrLIv0pXMd9+DBcTjHABx9oBR98ALFyo48QQpTGxsYND48hZtU9fvwpYmM/IDPzZDX3StyurHZJydChQxk6dGipxxcuXMjEiROZNGkSAIsWLWLjxo0sWbKEBQsWABAZGVnlfjRo0IAOHTqwY8cOHnrooWLHc3JyyMnJMb1PTU0FwGg0YjSWnoNZ1LzC8ajquLT0aMmZ5DPEJMUQ4FKxvNcOLRxI35dO6uFU7FrYVakfAG5u0KGDDX/9pbB5cx5jHh6O/p570O3YQcGLL1Lw9NMQHw8NG6L26WO1O1FaamxE9ZDxsV4yNlWTl5dnVr2MjIOcPXuQs2dfwsGhJfXrj6B+/ZG4uHRHUYrOXebkxGI0JpKXZ0SnO0NKSgQ2Nram47a2HhgMcgNmbavp74zVBtxlyc3NJTIykjlz5hQpv/fee9m1a1eV2798+TIODg64urqSmprKjh07eOaZZ0qsu2DBAt56661i5aGhoaZ14MK6bN68uUrnv+j1Ik4+TqQfSWfDkQ0VOtfByQE77Di4/iA59jnln2CGJk3a8tdfzfjmmzhcXA7i9re/0W/HDnQrV6JbudJUL8vDg0OTJhHfs6dFrlsdqjo2onrJ+FgvGZvK0enO4OJSfr3s7BD0+jPY2BwhK+sEFy6c4MKFf1FQ4EZeXjeMxu7k5XVEUVJxcZmGomjBnIsLHDlStC1VtSUt7VNUterZqkTlZWZa7n4qc9TJgDshIYH8/HwaNGhQpLxBgwZcunTJ7HaGDBnC/v37ycjIwN/fnzVr1tCtWzfi4uKYOHEiqqqiqirPPfccHTp0KLGNV155hdmzZ5vep6am0qhRI4KDg/Hw8KjcBxTVwmg0snnzZgYPHoytrW35J1SD8wfPE7s9lkZKI1rc38JCrSqsWwdnzgRw//1+KGvWlFjLPimJbu+/T/6PP6KOGmWha1uGNYyNKJ2Mj/WSsama9PQDHDxYfr27734ZZ+fO5OVdIzn5d5KS1pOc/DtwDTu7P7Cz+wOdzhFn566kppY9c6ooRvr27YCzc2fLfAhRKTWdfa5OBtyFbt22VVXVCm3lunHjxhLLg4KCiIqKMqsNg8GAwWAoVm5rays//KxUbY6Ncxstc0j2qWyL9SE4WFspcvaswoVYHU1eeKHEeoqqgqJg8/e/w4MPWuXyEvneWDcZH+slY1M5Dg4+6HT25ebhdnDwuf5v7ImDw2P4+j5GQUEuKSk7SEz8hYSEX8jJOU9q6g6zrmtjYyPjVctq+t+/Tgbcnp6e6PX6YrPZV65cKTbrLYSlJWcl8/T6pzmbfJZ9k/ehU8y/97gwU0nm8cwK/4JYGldX6N4ddu+G0KWneDIurvTKqgrnz0NYGPTvX+VrCyFEXVaZVIOFdDo76tcfRP36g2jW7CPS06O4cOEzLl1aWp1dFnWU1WYpKYudnR1BQUHF1qxt3ryZXr161VKvxJ3CxeDC+pPrOXDpADEpMRU616GZAyiQfy0f4xXL3bBhSg/4Z9mbQpjEx1vs2kIIUZdVNdUgaH9xd3HpjJ/fFLOuGRPzLklJmygoyK1q90UdYbUz3Onp6Zw+fdr0Pjo6mqioKOrXr0/jxo2ZPXs2jz/+OF27dqVnz54sXbqU2NhYpk6dWou9FncCG50NLT1acujKIY5ePUpT96Zmn6t30GPfxJ7s6GwyT2Ri16DqmUpA2wDnnXdg6/GGqEC58+YNG1rkukIIISouIeEnEhJ+Qq93xcNjGJ6eD1C//lBsbFxLrJ+dHVupWXhhPaw24N63bx/BhUmGwXRj4oQJE1i2bBljxowhMTGRefPmER8fT7t27diwYQMBARVL0yZEZbTxamMKuIe1GFahcxuMb0B+Wj623pZbP9azJ9jbQ3yigeMN+tP6ynZt+citFAX8/aFvX4tdWwghRMV4eoZw7dqfGI2XuXLlB65c+QFFscXdfSAeHg/g6TkSg8EX0ILtiIiW5a4z7979hATdVsxqA+7+/fuXu536tGnTmDZtWg31SIgbTFu8J1R8i/emb5o/I24ue3vo3VvbcXLriA9p/Z8uWnB963dIVWHRIqu8YVIIIe4UAQGv4ezcidTUcBISfiEhYQ1ZWSdJSvqdpKTfOXXqGVxc7sbT8wEcHFqUGWwDFBRkYzQmSMBtxerkGm4halthwP3z0Z/Zd3FfLfdGY1rHndgJVq0CP7/ilVq0ACtLCSiEELcLW1tPdLqy76XR6eyxtfVEUXS4ufXkrrve5e67T9Ct2zGaNl2Aq2sPANLSwomOfpWjR0fXRNdFNbPaGW4hrFlhwJ2Wm8Y3B7+hq29Xs89VVRVjgpHs6Gxcu5e8Xq8yBg6E116Dbdsg/6cQ9A88oGUjiY8HW1uYMAFOnoQVK+CRRyx2XSGEEJqbs57k5eWxc+dO+vTpg43NjXCrtPXWTk6tcHKaQ0DAHHJy4klMXEdCwi8kJW0GzNsRU1gvCbiFqICYlBgSMhPIK8hDQUFF5YfDP/BEpydQVRVPR08C6pV9H0HupVx2++4GPdyTeQ86O8v8oSkoSNvVLDkZDh6ELl30RVP/HT8Oc+fCSy/BAw+Ag4NFriuEEOIGe/vG2Ns3xmg0UlAQj7Nz5wrnfDYYGuLrOwVf3ymkpOwgKqpfuefk56dVtsuiBsiSEiEqoMniJnT9ois9/tPDVJaYmUjQ0iC6ftGVJoublNuGnY8dejc9Bn8DuZctlxLKxgb6Xf+ZvGVLCRVeeAEaNdLycP/f/1nsukIIIaqPXu9sVr2oqEEcPHgfFy9+Tk6OpH61NhJwC1EBy0ctx0an/WFIRS3ybKOzYfmo5eW2oSgKva/0pue5ntg3MjNvtpkGDtSet24t4aCDA7z/vvZ6wQK4eNGi1xZCCFGb8khO3sjJk1PZvduX/ft7Ehv7PpmZJ0usnZ0dS1ra/lIf2dmxNdz/25ssKRGiAsZ1GEdrr9YELQ0qdmzPxD0E+RYvL4mllpHcqvDGyR07IDcX7G5N8z1mDHz0kbYt5auvwrJl1dIPIYQQNatNm1VkZZ0iIWEtaWnhpKbuITV1D2fPvoyjYxs8Pf+Gp+coXFyCyMk5L6kGa5jMcAtRSbpbvj6/HP+llnpyQ7t24OUFmZkQEVFCBUXR0gICfP01REbWZPeEEEJUkLmZT1xduxEQMIegoD307BlH8+af4u5+L4piQ2bmUWJj57N/fzf27GnMmTMvmp1qUFiGzHALUUHeTt74OPvQyLUREztP5O0dbxOXFse/dv+LCZ0mcFf9u8ptIy0yjdOzT2PjZkP7de0t1jedDoKDYeVKbR13nz4lVOreHR5/HL79FmbO1KbDlXL3phRCCFELbs58UppbM58YDH74+T2Dn98zGI0pJCVtICFhDYmJ/yMnJ46rV1fWRNfFTWSGW4gK8nf159yMc4RPCmdK1ylEz4imT+M+ZOVlMX7tePIL8sttQ7FRuLbjGtd2Xit3g6eKKnMdd6H587U13Tt3ajm7hRBCWC17+8a4uHQp9VHWsg9b23o0aDCWtm1/onfvBNq3/xUPjwdqsPcCJOAWolIMNgaU67PCNnobvh31LS52Luw6v4v3/3y/3PMdmmsp+fKS8zAmGC3at8J13Lt3a0tLSuTvDy+/rL3++99h0yb44YfrSbzL/4VBCCFE3aPX2+PhMYwmTf5hVv0rV1aSkyM32FuCBNxCWECTek34eOjHAPxj2z84EH+gzPp6Rz2GAAMAmSdKi4or5667tOx/RqM2gV2qF18EDw+IjYUhQ2DsWG09SpMmsHq1RfskhBCi7jl//j127/a7KePJqVLrStaTsknALYSFjO84npDWIeQV5PHvvf8ut75jS0cAsk5kWbQfimLmspLff4fExOLlFy7A6NESdAshxB3OyUm7x6gw20lERAv27m1PdPQ/SEs7YFoSmZ0dS0RESyIjg0p9RES0vKODbgm4hbAQRVH4fPjnfDjkQz4f/nm59QsDbkvPcMONZSUlboAD2rKRGTNKPla4pnzmTFleIoQQd7BWrZbRs+dFmjdfgrv7YBTFhoyMw8TE/JPIyC6Ehwdy+vRskpI2SdaTckiWEiEsyNPRk5k9ZppVtyYC7v37ta3e3d1vqRAWBnFxpTegqtqOlGFhRbeHF0IIUecVphosLw+3ra0nBkND/Pym4uc3FaMxmcTEX0lIWENS0u9kZ58jLu7DGux53SUBtxDVJMuYxfyw+czuORt3h1sjXnBoqd04mXnc8gG3nx+0bAknTsD27fC3v91SId7MbX/NrSeEEKLOqEyqQa3MHR+fx/HxeZz8/EySkjaSkLCGhIQ15OenV3e36zQJuIWoJo/8/AjrTqzjbMpZvgv5rthxx1baDHf22WwKjAXobC27wmvgQC3g3rq1hIC7YUPzGjG3nhBCiDrF3r5xlXaR1Osd8fIahZfXKK5di+DAgbvLPScvL7XS16vrZA23ENXk1T6volf0fH/oe1YcXlHsuMHPgM5Jh5qnkn227LVvlVG4rGTNGi1u/umnmw727aulBixtwxtF0VKd9O1r8X4JIYS4veh05s3fHjw4iIMHh3Dx4lJycy9Xc6+siwTcQlSTu/3v5tW+rwLwzG/PcCH1QpHjiqLg2KL61nEXLr2Oi4NLl2DyZLhy5fpBvR4WLy7sSPGTVVXbAl6vt3i/hBBC3KnySU7exMmTU9i1qyEHDtzD+fOLyM6OKbH27ZRqUAJuIarR3HvmEtQwiOTsZJ785UkiLkQw4OsB7Lu4D7jpxslqWMddvz64ud14n5YGzzxzU4WQEG2XST+/4ifb20Pv3hbvkxBCiDtX27arCQx8FxeXboDKtWthnDkziz17mhAZ2Y2YmAVkZp4Abr9UgxJwC1GNbPW2LA9Zjr2NPZvPbualzS8Rei6Ubw9+C9xYx10dM9wrV8K1azfe5+drqbVXrrypUkgInDsHoaHw/fdaHsGgIMjOhrlzLd4nIYQQt5/CrCdl0enscXEJonHjlwkKiqBHjxiaNVuMm1s/QEda2j6io18lIqIVERFtOXfun7dVqkG5aVKIauZg48D07tP5YNcHhMWEAfDjkR+Z0GkCed3zqP9ufXz7+1r0mleuwNSp2mqRwrTaoL2fMkVbbuLtfb1Qry+a+m/xYujTB778Ep59Fjp2tGjfhBBC3F4qk/XE3r4x/v7P4+//PLm5V0hI+IWEhNUkJ28hM/MomZlHa6LrNUYCbiGqWZPFTUyvVbTo92rGVYKWBt0ov1u99bRKU1Ut2E5LKxpsFx4rXFry88+lNNC7N4wZAytWwKxZ2qx3aTdXCiGEEFQt64mdnTe+vk/j6/s0RmMKSUm/ER//H1JSQi3cy9ojS0qEqGbLRy3H5vod3IUBd+Gzjc6G5aOWW/R6R45omUlK2ySycGnJkSNlNPLee2AwaEtN1q2zaP+EEEKI0tja1qNBg3Hcdde/zKp/7douCgqM1dyrqpOAW4hqNq7DOMInhZd4LHxSOA8oD3D5u8tkncuyyPXatoVRo0pPMKLXa0u327Yto5GAAHjhBe31Cy9ATo5F+iaEEEJY0unT09m1y5tjxyaQkLCe/HzLp9m1BAm4hahBulu+cpnGTM7MPsOxx46REppikWsoCnz2Gbi4lLwSxNUVliwxo6E5c8DHB86cgU8+sUjfhBBCCEuysalPXl4Kly9/w+HDI9m1y4ujRx/l6tWfyc/PKFa/MNVgevrBGu2nBNxC1ABvJ298nH0I8g1i4ZCF2OpsAfhs32e49nDFra8bNq6Wu6XC21sLum9dww1auemGybK4uMD8+drrefPg6lWL9U8IIYSwhA4dfqdTpx34+T2PweBPfn46V678yJEjo/nzTy8OH36Qy5e/Jy8vtUiqwcOHB9ZoP+WmSSFqgL+rP+dmnMNOb4eiKHTw7sCgbwfx3aHvePTxRxn2z2EWv+bDD2v3Pa5bV3Q9d4cOFWhkwgT4+GM4cAD+8Q8zp8aFEEKIqilMNVhWakCdzh47uwbY2zemXr2+NGv2IWlpe7l6dRVXr/5MdnY0CQmrSUhYjaLY4ep6d7mpBquLBNxC1BCDjcH0emDgQGb1mMWHez5k4rqJHHrmEF5OXha9XuHSktBQSEkBW1swGmHpUli40MxGdDptx8l+/bQTp0zRGouP1/aL79tXdqMUQghhcZVJNagoOlxd78bV9W4CA98nPT3KFHxnZZ3g2rWwmuh6iWRJiRC1ZP7A+bTxasPljMtM/nUyeZl5qAWWSw8I2tKRzz/XlmIX3gP59deQVZH7M++5B0aPhoIC6NEDgoNh7FjtuUkTLeWJEEIIYWH29o1xcelS6qOsNISKouDi0pnAwHfo3v0Y3bodpmHDKTXY+6Ik4Bailtjb2LN81HJsFVsemP4AO513knXaMplKbvbww9qE9NtvQ+PGkJSk7eheIQMGaM+3Ziu5cEELxiXoFkIIYaUURcHJqS2+vpNrrQ8ScAtRizo37MyH932If31/UKtni/dCej08/bT2+vPPK3Bifv6NmydvVXhX5syZpSf+FkIIIe5wEnALUcue7f4sDTs2BKo34AaYOFELvP/8Ew4fNvOksDCIiyv9uKrC+fNaPSGEEEIUIwG3EFbAsZUjAImHE1l9rPqWZzRsCA88oL02e5Y7Pt6y9YQQQog7jATcQlgBx5ZawL1n+x4eWfUIBy9VX0L+qVO152+/hYziewIU17CheQ2bW08IIYSoBYWpBmuDBNxCWIHCgDsgKQBjgZHH1jxGdl715AodOBACA+HaNS1Pd7n69gV//5K3rQStvFEjrZ4QQghhpQpTDQYFRdKu3ZYavbYE3EJYAYcWDgA4pjrSVGnK4SuHeX3r69VyLZ0OJl+/UdusZSV6PSxerL0uLehetEjycQshhLB6hakGnZ071uh17+iAe9SoUbi7uzN69Ohix2xsbOjUqROdOnVi0qRJtdA7cSexcbHBzs8OgI9bfgzAwt0LCY0OrZbrPfmkthFORIS2iWS5QkK0XIJ+fsWPvfKKdlwIIYQQJbqjA+7nn3+eb775psRj9erVIyoqiqioKL788ssa7pm4ExUuK+mS1YWnuzyNisqEtRMIjQ5lwNcD2Hdxn8Wu5e19I0Y2++bJkBA4d07buvL772HMGK189WptC0shhBBClOiODriDg4NxcXGp7W4IAdwIuLNOZLFwyEIC3QM5n3qeFza9QOi5UL49+K1Frzfl+oZb330HaWlmnqTXQ//+8OijWqTu5QXHj2t7yAshhBCiRFYbcO/YsYMRI0bg6+uLoiisXbu2WJ1PP/2Upk2bYm9vT1BQEGEWzAOcmppKUFAQffr0Yfv27RZrV4jSFKYGzDyRSWJmIq/3fZ2Q1iHEpWo5sH888iP74/cTeTGSmJSYKl+vf39o0QLS07UJ6wpzc4N//lN7/cYb2haWQgghhCjGprY7UJqMjAw6duzIk08+yYMPPljs+IoVK5g5cyaffvopvXv35vPPP2fo0KEcPXqUxo0bAxAUFETOrVtRA5s2bcLX17fM6587dw5fX18OHz7MsGHDOHToEK6urpb5cEKUoHCGO/NEJu0XtzeVK2g3Kl7NuErQ0iBTufqGWqXrKYo2y/3CC9pk9eTJpd8TWaqJE+Hf/4ZDh+Ctt27cXCmEEEIIE6sNuIcOHcrQoUNLPb5w4UImTpxouqFx0aJFbNy4kSVLlrBgwQIAIiMjK339woC8Xbt2tGnThpMnT9K1a9di9XJycooE9ampqQAYjUaMsq7VqhSOh7WOi22gLQBZp7JYdv8yJv0+ibyCPFS0wLrw2UZnw5fDv7TI5xg7Fl591YYDBxT27Mmja9eKB/HKBx9gc999qP/+N3kTJ0Lr1hVuw9rH5k4n42O9ZGysl4yNdavpcbHagLssubm5REZGMmfOnCLl9957L7t27apy+8nJyTg6OmIwGIiLi+Po0aMEBgaWWHfBggW89dZbxcpDQ0NxdHSscl+E5W3evLm2u1CyArCZY0OBfwH14urxXrP3eOHkC8WqvdfsPerF1mND7AaLXLZHjy5s396IuXMvMH16VKXa6N69Ow0jIkh86inC586tdF+sdmwEIONjzWRsrJeMjXXKzMys0evVyYA7ISGB/Px8GjRoUKS8QYMGXLp0yex2hgwZwv79+8nIyMDf3581a9bQrVs3jh07xpQpU9DpdCiKwuLFi6lfv36JbbzyyivMnj3b9D41NZVGjRoRHByMh4dH5T6gqBZGo5HNmzczePBgbG1ta7s7JRt+4+WBSwfgJOjQUUCBqdyvnR/3t7rfYpd0c1MIDobduxvz44++uLlVopHmzVE7dcInMpJhej3qkCEVOr1OjM0dTMbHesnYWC8ZG+uWmJhYo9erkwF3IeWWBaeqqhYrK8vGjRtLLO/VqxeHDh0yqw2DwYDBYChWbmtrK18wK1VXxsbXzRcfZx8auTbiyc5PMmfzHFJzU5n/53xC2oRgq7fMZ+jXD9q2hSNHFFassOXZZyvRSJs2MH06LFyIzcsvw333gU3Ff7zUlbG5U8n4WC8ZG+slY2OdanpMrDZLSVk8PT3R6/XFZrOvXLlSbNZbiLok40gGMQtiiF8Wj7+rP+dmnCN8UjjPdH2GI9OOUM9Qj78u/8XbO9622DULb54ELbufWtl7MefOBQ8POHoUli61WP+EEEKIuq5OBtx2dnYEBQUVWxe1efNmevXqVUu9EqLq0g6kEf1qNJe+0n6ZNNgYTH+18Xfz57PhWr7rd8LeYU/cHotd9/HHwcEBDh+G3bsr2Ui9ejBvnvZ67lxYvx5++AG2bYP8fAv1VAghhKh7rDbgTk9PN+30CBAdHU1UVBSxsbEAzJ49my+//JL//ve/HDt2jFmzZhEbG8vUqVNrsddCVI1LFxcaPNYArwe9Sjw+pt0YxrYfS76az1O/PEV+gWUC2Xr14JFHtNdV2sNm8mTw99dyco8cqaVBCQ6GJk20HSmFEEKIO5DVruHet28fwcHBpveFNyZOmDCBZcuWMWbMGBITE5k3bx7x8fG0a9eODRs2EBAQUFtdFqLKnNo40frbstPqfTL0E65mXGXBwAXodXqLXXvKFPjqK1i5EhYtglLuEy7bunUQF1e8/MIFGD0aVq26sae8EEIIcYew2oC7f//+qOUsJp02bRrTpk2roR4JYR3cHdzZ9Pgmi7fbvTt07AgHD8I338DMmRVsID8fZswo+ZiqaovFZ86EBx7QtogXQggh7hBWu6REiDtVQV4BmSczyY7LNqv+wUsHuZpxtcrXVRQoXJFVqZsnw8JKnt0upKpw/rxWTwghhLiDSMAthJU5Pf00ES0juLjkYrl1v476mm5fdGPKr1PK/YuQOcaOBScnOHECduyo4Mnx8ZatJ4QQQtwmJOAWwso4tHQAIPNE+btgdWjQAYA1x9fwzcFvqnxtV1cYN057/fnnFTy5YUPL1hNCCCFuExJwC2FlHFs6ApB1Iqvcup0bdmZesJaKb/r/pnMu5VyVr1+Yk3vVKrhakZUqfftqGUpK23xKUaBRI62eEEIIcQeRgFsIK1MYcGecyCCiTQRJfySVWf/FXi/Su1Fv0nLTGL9mfJVTBXbpAl27gtEIy5ZV4ES9HhYv1l6XFHSrqpb+RG6YFEIIcYeRgFsIK2MfYA92gBEyj2US/Wp0meuz9To934z6Bmc7Z8Jiw/i/3f9X5T4U3jz5+edQUFCBE0NCtKlxP78SOqqHDh2q3DchhBCirpGAWwgro+gVDA0Npvdpe9NI3pRc5jmB7oEsvk+bXX596+usOrqKAV8PYN/FfZXqwyOPaOu5z5yBrVsreHJICJw7B6Gh8P332vOQIVrawBdfrFR/hBBCiLpMAm4hrIyqquRdy7tRoIfouWXPcgM82elJxrQdw/yB89l+bjuh50L59uC3leqDkxM89pj2usI3T4I2m92/Pzz6qPa8cKFWtnZtJSJ4IYQQom6TgFsIK5O8KZn8lJvWYeebN8sdey2Wv/f8OwOaDmDl0ZUA/HjkR/bH7yfyYiQxKTEV6kfhzZNr18KlSxU6tbg2beCZZ7TXs2Zps91CCCHEHUICbiGsiKqqRM+NhlvvKzRjlrvJ4iZ0+7IbQUuDTBvhXMm4QtDSILp+0ZUmi5tUqC8dOkDPnpCXB//9bwU/SEnefBPq1YO//rJQg0IIIUTdIAG3EFYkeVMyaXvT4NYJYDNmuZePWo6NzgYAlaKBuY3OhuWjlle4P4U3Ty5daoFJaQ8PLegGeP11SE2tYoNCCCFE3SABtxBWwjS7Xdq3Ulf2LPe4DuMInxRe4rHwSeGM6zCuwn166CFwd4eYGNi0qcKnFzdtGrRoAVeuwPz5FmhQCCGEsH4ScAthJdRclezYbCgtDV8BZJ/PRs0tfwt33S1f7S1nt1SqTw4OMH689rpSN0/eytYW/u962sIPP4SzZy3QqBBCCGHdJOAWwkroDDqC9gYRFFn0EfhBIM0WN9Pe7w1CZyj9a+vt5I2Psw9BvkF8NuwzGjpr26jP3zmf+LT4SvWr8ObJ9eshLq5STRQ1bBgMHgy5ufDSSxZoUAghhLBuNrXdASHEDfaN7LFvZF+kzKWLi9nn+7v6c27GOez0diiKwhOdnqD7l9356/JfTFo/iV8f/RWltK3XS9G6NdxzD+zYAf/5D7zxRoVOL05RtDSBHTvCzz/DokUoHh54xMRo+bptbat4ASGEEMK6yAy3EHVIdlw2V1ZeKbOOwcZgCqoNNga+C/kOg97AhlMb+M+B/1TquoWz3F9+qWUtqbJ27bRZboBZs7AZP54+c+di06wZrF5tgQsIIYQQ1kMCbiHqiKzoLPa228uxx46Rfijd7PPaebdj/sD5DA4czNBmQyt17QcfBE9PbUnJhg2VaqKo1atLvgvz4kUYPVqCbiGEELcVCbiFqCPsm9hTr389nDs7o7Or2Fd3Zo+Z/P7Y7/i5+lXq2gYDPPGE9vrzz2HlSmjYEH76qRKN5efDjBlQQrYVpbBs5kzZHEcIIcRtQwJuIeoIRVFo/XVrOv/ZGceWjhU6V6fo0Ck3vu5nkyueHWTyZO15wwZ4+mlt98nJk7UMfxUSFlb23ZeqCufPa/WEEEKI24AE3ELUITZuNuhsbnxtC4yl5RAsmTHfyOT1k2n1SSsOxB+o0LnNm8OAAdrrtLQbz4U7tpst3sxsKebWE0IIIaycBNxC1EH52fmcefkMB3ofqFDQbaOzISkrCWOBkcfWPEZ2XnaFrtuhg/ZcuPIjP19bbr1yZQUaadjQsvWEEEIIKycBtxB1UF5KHvFfxJO2N43Y92LNPk9RFD4b/hkNnBpw9OpRXt3yqtnnXrkCX31VUptaFhOzl5b07Qv+/tqJJXcSGjXS6gkhhBC3AQm4haiDDD4Gmn/cHICYeTGk/2V+1hJPR0/+M1JLD/jhng/ZGr213HNUFaZOhfQSLqOqFVxaotfD4sXa61uCbtNtlIsWafWEEEKI24AE3ELUUd5jvfEY6YFqVDn+5HESf08kok0ESX8klXvusBbDmBKkJdd+Yu0TpGSnlFn/yBFYs6b0xCGFS0uOHDGz8yEhsGoV+N2SNcVg0MpDQsxsSAghhLB+EnALUUcpikKLz1pg425D+v50Tkw6QeaxTKJfjUYtIeXerf5177+4y/0uzqeeZ/r/prPv4j4GfD2AfRf3Favbti2MGlX6pLNer8XIbdtW4AOEhMC5cxAaSt67794ov//+CjQihBBCWD8JuIWowwwNbywtyb2QC0Da3jSSNyWXe66znTPfjvoWH2cfQlqF8M3Bbwg9F8q3B78tVldR4LPPwMWl+NJrRQFXV1iypBIfQK+H/v1RZ80i290dJScH9uypRENCCCGE9ZKAW4g6zutRL/T1bpp61kP0XPNmuX1dfFn10CoC6gWw4sgKAH488iP74/cTeTGSmJQYU11vby3ovrVZVdXKvb2r8CEUhYR27bTXoaFVaEgIIYSwPja13QEhRNWkbE4hP+WmxdX5N2a56w+pX+a5TRY3Mb1W0Kaur2ZcJWhpkKlcfeNGhP3ww7BiBaxbd2M9t50djBxZ9c+R0L49/mFhWsD91ltVb1AIIYSwEjLDLUQdpqoq0XOj4da11TrzZrmXj1qOjU77vVu9niOk8NlGZ8PyUcuL1L95aUnh+9xc+OGHqn+WhPbttRd79kBmZtUbFEIIIayEBNxC1GHJm5JJ25sGt2YPKTBvLfe4DuMInxRe4rHwSeGM6zCuWLm3N3z+Ofj4wNixWtmHHxZfalJRGT4+qI0agdEIf/5ZtcaEEEIIKyIBtxB1lGl2u4xvsblruQF0tzSUV5BXat2HH9Z2Xv/4Y3B0hEOHYGv56bzLpiio/fppr6vcmBBCCGE9JOAWoo5Sc1WyY7OhjJ3ds89no+aWHXB7O3nj4+xDkG8Q8wfMR6doPxZWH11dbh/c3eHJJ7XXH35odtdLVdC/v/ZCbpwUQghxG5GbJoWoo3QGHUF7gzBeNRY7phaoKDoFW29bdIayf6/2d/Xn3Ixz2OntUBQFXxdfnvjlCRbuWcgj7R+hk0+nMs+fMQM+/RR++w1OnICWLSv/mdTCgHvvXvjvfyEwUNviXXadFEIIUYfJDLcQdZh9I3tcurgUe7h2dcWliwv2/vZknsgsd1mJwcaAcj3B9viO4wlpHYKxwMhjqx8jOy+7zHObN4fhw7XXixZV7fMokZFacF1QABMnQnAwNGmibWMphBBC1FEScAtxG4tZEENE2wguLbtk9jmKovD58M/xcfbhnoB7KFDLWLNy3axZ2vPXX0NiYuX62nD3bvSPPFJ8//gLF2D0aAm6hRBC1FkScAtxG1N0CuRD6q7UCp3n6ejJkWlH+HTYpzjaOpZbv39/6NQJsrJg6dJKdDQ/n/ZffllyqpPCspkziwfjQgghRB0gAbcQt7FGf29E+w3taflFxRdW13e4sWlOgVpAljGr1LqKcmOW+5NPtNzcFaHs3IlDYiJKaRVUFc6fh7CwijUshBBCWIE7OuAeNWoU7u7ujB49ukj5iRMn6NSpk+nh4ODA2rVra6eTQlSBolfwGOpRpTZir8Uy+NvBTNswrcx6jzyi5ea+eBF++qmCF4mPt2w9IYQQworc0QH3888/zzfffFOsvGXLlkRFRREVFcXOnTtxcnJi8ODBtdBDISwnNyGXI48cIS0qrULnxV6LJTQ6lGVRy1h7fG2p9ezs4NlntdcLF1ZwI5yGDS1bTwghhLAid3TAHRwcjEvhHtWlWLduHQMHDsTJyamGeiVE9Tj78lmurrjK8cePk59t/lroPo378FLvlwB4ev3TXE6/XGrdqVPB3h7276/Y6g+1Tx+yPDxQlVIWlSgKNGqkpQgUQggh6hirDbh37NjBiBEj8PX1RVGUEpd0fPrppzRt2hR7e3uCgoIIq4b1nStXrmTMmDEWb1eImhb4biC23rZkHM4g+vXoCp37Vv+36NCgAwmZCTy9/ulS0wx6esL48drrCm2Eo9dzaNIk7fWtQXfh+0WLJB+3EEKIOslqA+6MjAw6duzIJ598UuLxFStWMHPmTF577TUOHDhA3759GTp0KLGxsaY6QUFBtGvXrtjj4sWLZvUhNTWVP//8k/vvv98in0mI2mTnZUfL/2g3T8YtjCM5NNnscw02BpaPWo6d3o71J9fzVdRXpdadOVN7/uUXOHPG/P7F9+xJ/o8/gp9f0QPu7rBqFYSEmN+YEEIIYUWsdqfJoUOHMnTo0FKPL1y4kIkTJzLp+qzYokWL2LhxI0uWLGHBggUAREZGVqkPv/zyC0OGDMHe3r7UOjk5OeTk5Jjep6Zq6deMRiNGY/EdAEXtKRyPO3lc3Ia40WBSAy5/eZljE44RuDCQmLkxBH4YSL2B9co8t1X9VrzV7y1e2foKM36fQR//PjSt17RYvWbNYMgQPRs36li0KJ+FC8vP4104JrnDh6OOHImycye6jz5Ct349BYMHkz9iBNzB41bb5LtjvWRsrJeMjXWr6XGx2oC7LLm5uURGRjJnzpwi5ffeey+7du2y2HVWrlzJ5MmTy6yzYMEC3nrrrWLloaGhODqWn79Y1LzNmzfXdhdq10Bw/tWZ3PO5HH3qKLo0HQenHyTjgwxKz8unaaG2oI1TG1LzUvl9y+8YVSNfX/yaCb4TaObYzFSvRw8vNm7sxZdfqvTosQln5zyzunbz2Hh2707v9evJ3bSJjb/9Vnypiahxd/x3x4rJ2FgvGRvrlJmZWaPXq5MBd0JCAvn5+TRo0KBIeYMGDbh0yfwd9YYMGcL+/fvJyMjA39+fNWvW0K1bNwCuXbtGREQEP//8c5ltvPLKK8yePdv0PjU1lUaNGhEcHIyHR9XSsQnLMhqNbN68mcGDB2Nra1vb3alVqX6pHOp3CF2atqrM5rQNPW174n6ve7nndkvvhpvBDQdbB2ZtmsWhk4c453qO5+993lRn6FD46SeVo0dtiIu7j9mzy57lLnFsBgxAfecd7JOTub9JE2jbttKfV1SNfHesl4yN9ZKxsW6Jld0WuZLqZMBdSLllxktV1WJlZdm4cWOpx9zc3Lh8ufRsDIUMBgMGg6FYua2trXzBrJSMDdTvUx87Hzty46/vUKOD82+dx+t+r3K/QwVKAadSTqEoCj8d0xJurzy2kie7PImqqng6ehJQL4DZs2HSJPj0Uz0vvKDHxoyfNkXGxtZWy0qyeTO227drW1mKWiXfHeslY2O9ZGysU02PidXeNFkWT09P9Hp9sdnsK1euFJv1FkIUl7wp+UawDVAAaXvTSN5U/o2UTRY3oesXXQlaGsSVjCsAXM24StDSILp+0ZUmi5sAMG4ceHlBbCysXl3Jjg4cqD1v2VLJBoQQQojaVycDbjs7O4KCgoqti9q8eTO9evWqpV4JUTeoqkr03Gi4NcOeAtFzo0tN+Vdo+ajl2OiKTleraOfY6GxYPmo5oOXjfuYZ7XiFUgTebNAg7XnbNsgzbx24EEIIYW2sNuBOT0837fYIEB0dTVRUlCnt3+zZs/nyyy/573//y7Fjx5g1axaxsbFMnTq1FnsthPVL3pRM2t40uHXvG9W8We5xHcYRPim8xGPhk8IZ12Gc6f20adoOlHv2wO7dlehsp05aWsC0NNi7txINCCGEELXPagPuffv20blzZzp37gxoAXbnzp35xz/+AcCYMWNYtGgR8+bNo1OnTuzYsYMNGzYQEBBQm90WwqqZZrdL++abOctdSHdLQz8e+rHI+wYNYOxY7XWlZrn1eggO1l7LshIhhBB1lNUG3P3790dV1WKPZcuWmepMmzaNc+fOkZOTQ2RkJPfcc0/tdViIOkDNVcmOzYbSkoaokH0+GzW37IDb28kbH2cfgnyD+GzYZ/i7+APwr93/YsOpDUXqzpqlPf/8M8TEVKLThctKVq2CH37Qlpfkm781vRBCCFHb6nSWEiFExegMOoL2BmG8WnrCf1tvW9Kj0nG927XUOv6u/pybcQ47vR2KovB0l6d56pen+PqvrxmzagwnnztJQ5eGAHTooN37uGULfPwx/OtfFex0YXB98OCN6XJ/f1i8WHafFEIIUSdY7Qy3EKJ62Deyx6WLS4kP507OnJt7jv099nN1zdUy2zHYGEwpBHU6HUtHLmVw4GDeH/S+KdguVDjL/cUX2nJss61eDc8/X7z8wgUYPboK6U+EEEKImiMBtxDCRNEp2HrZgg6yY7IrdK6d3o7fH/udZ7o9U+zY0KHQsiWkpsJXX5nZYH4+zJgBJa0nLyybOVOWlwghhLB6EnALIYpo+k5TuuzuQqOZjSp8rk658SMlKSuJd3a8Q4FagE6nxc4AixaZGSOHhUFcXOnHVRXOn9fqCSGEEFZMAm4hRBE6Wx2u3W+s3y7IK3tb9pLkFeTRb1k/Xg99nblb5wIwfryW4S86GtatM6OR+HjzLmZuPSGEEKKWSMAthChVxvEMIrtEcvXnstdz38pGZ8Pfe/4dgPk757MsahlOTlCYJt+sFIENG5ZfpyL1hBBCiFoiAbcQolSXl18m41AGx586TtaZrAqdO6HTBF7r+xoAk9dPZvu57Tz7LNjYaKtAIiPLaaBvXy0byfUbM4tRFGjUSKsnhBBCWDEJuIUQpWryRhNce7uSn5rPkYePkLghkYg2EST9kWTW+fOC5/FQm4cwFhgJWRlCpv0pBo3fB+MH8Pqn+8o+Wa/XUv9B8aC78P2iRVo9IYQQwopJwC2EKJXOVkebH9tg42FD+v50jj95nMxjmUS/at5ulDpFx9d/+5q7/e4mKSuJYd8Pw6HPUggMZeOlb7lwoZwGQkK0DW/8/IqW16+vlUsebiGEEHWABNxCiDLZ+9vT+tvWABivaBvmpO1NI3lTslnnO9g68Mn9n+Dj7ENGbgY7rmq5s9U2P/L6v/cTeTGSmGtlbEEZEgLnzkFoKIwYoZUNGiTBthBCiDpDdpoUQpSr/n31sWtoR258rlagh+i50bjf627a/KYs3b7oZnqtcL2+01WWKUEs+0J7u7bT2tIb0Ouhf3+ws4P16+H338FoBFvbyn0gIYQQogbJDLcQolzJm5JvBNsA+RWb5V4+ajk2Ou33e5XrS1EU7VmHDctGLjOvI3ffDV5ecO2a5N8WQghRZ0jALYQok6qqRM+NhlvvTbw+y23OWu5xHcYRPim8xGP+/wvnkTZjzeuMXn9jWckvv5h3jhBCCFHLJOAWQpQpeVMyaXvT4NbdISs4y30r3fUfP7Gx8PrrOp54YgirVpW/PIWRI7XndetK3vZdCCGEsDIScAshSmWa3S7tJ4XO/Flubydv3O3dAfB18SXINwjHAh/I8GbRIh0pKQamTdNz5Uo5DQ0aBAaDdiPl++/Dtm1m7hUvhBBC1A4JuIUQpVJzVbJjs6G03d0LIPt8Nmpu+QG3v6s/34V8B0B9h/qETwpn//hzkOpPXp4CKKSlwTPPlNPQxo038nDPmQPBwdCkCaxebeanEkIIIWqWZCkRQpRKZ9ARtDcI41UtHeCxx46ReSyTZoub4dbHDQBbb1t0BvN+d7fT25leK4pC1D5DkeP5+QqrV8PKlfDwwyU0sHo1jB5dfCnJhQtaueTmFkIIYYUk4BZClMm+kT32jewBbefJ3Cu5eIzwwKGJQ5XavXIFpk7VJqtvjp8VBaZM0bIAenvfdEJ+PsyYUfK6bVXVTpw5Ex54QHafFEIIYVVkSYkQwmzeY7zxn+5f5WAbtGA7La14/KyqlLy0JCwM4uJKb1BV4fx5SRcohBDC6kjALYSocdnZsGZN6fc65udrq0eOHLmpMD7evMbNrSeEEELUEFlSIoQwW9qBNPLT8nFq64StR8V3eWzu0ZyF9y6kvoMHv4zSMvuVFHTr9drKkLZtbyps2NC8i5hbTwghhKghMsMthDDbySknieoXReqe1Eqd39itMbN6zmJCp/F89hm4uNxIOFJIUcDVFZYsueXkvn3B37/4CTef2KiRVk8IIYSwIhJwCyHMZh9gj0NLB3ROVf/R4e0Nn31W8hruzz675YZJ0Ka9Fy/WXpcUpQMsWiQ3TAohhLA6EnALIczW9qe23H38btz7u1fq/GvZ19h1fhcH4g8AWuq/UaNAUbSoW1FUQkJKSQkIWsq/VavAz69oub+/pAQUQghhtSTgFkLUmP3x++n93948vuZxQJuY/uwzsL2+HNxgKGEpya1CQrRdJvv3194//zxER0uwLYQQwmpJwC2EqFXe3tC/vzbDPXRoQfGlJCXR62+sOWneXJaRCCGEsGoScAshzHZ07FH2tt9LyvYUi7bbrJkWcLdubdFmhRBCCKsgAbcQwmxZZ7LIOJxBXlpetbRf0iaSQgghRF0nAbcQotaVlulPCCGEuB1IwC2EEEIIIUQ1koBbCCGEEEKIaiRbuwshakxT96b8M/ifeDl6lXhc1nALIYS4HUnALYSouEoGxk3qNeH1e14vVi5ruIUQQtzOZEmJEEIIIYQQ1UhmuIUQNSY9N50zSWcw2Bho5dmqtrsjhBBC1AiZ4RZC1Jh9F/fR6fNOhKwoeRt2WcMthBDidiQBtxCi1skabiGEELczCbiFEEIIIYSoRhJwCyGEEEIIUY3kpkkLU68vQk1LS8PW1raWeyNuZjQayczMJDU1Vcamkpwfdca2vy3GhkZSU1MrfH5GWgZkQ35WfpHzc3PzAT3Z2fmkpurNa8xo1J4zM6ESfRHmk++O9ZKxsV4yNtYtLS0NuBG3VTdFrakr3SHOnj3LXXfdVdvdEEIIIYQQ5Thz5gyBgYHVfh2Z4baw+vXrAxAbG4ubm1st90bcLDU1lUaNGnH+/HlcXV1ruzviJjI21k3Gx3rJ2FgvGRvrdu3aNRo3bmyK26qbBNwWptNpy+Ld3NzkC2alXF1dZWyslIyNdZPxsV4yNtZLxsa6FcZt1X6dGrmKEEIIIYQQdygJuIUQQgghhKhGEnBbmMFg4I033sBgMNR2V8QtZGysl4yNdZPxsV4yNtZLxsa61fT4SJYSIYQQQgghqpHMcAshhBBCCFGNJOAWQgghhBCiGknALYQQQgghRDWSgFsIIYQQQohqJAG3BX366ac0bdoUe3t7goKCCAsLq+0u3fYWLFhAt27dcHFxwdvbm7/97W+cOHGiSB1VVXnzzTfx9fXFwcGB/v37c+TIkSJ1cnJymD59Op6enjg5OTFy5Eji4uJq8qPc9hYsWICiKMycOdNUJmNTey5cuMBjjz2Gh4cHjo6OdOrUicjISNNxGZvak5eXx+uvv07Tpk1xcHAgMDCQefPmUVBQYKoj41MzduzYwYgRI/D19UVRFNauXVvkuKXGITk5mccffxw3Nzfc3Nx4/PHHSUlJqeZPV/eVNT5Go5GXX36Z9u3b4+TkhK+vL+PHj+fixYtF2qix8VGFRfz444+qra2t+sUXX6hHjx5VZ8yYoTo5OakxMTG13bXb2pAhQ9SvvvpKPXz4sBoVFaUOGzZMbdy4sZqenm6q8+6776ouLi7qzz//rB46dEgdM2aM2rBhQzU1NdVUZ+rUqaqfn5+6efNmdf/+/WpwcLDasWNHNS8vrzY+1m0nIiJCbdKkidqhQwd1xowZpnIZm9qRlJSkBgQEqE888YQaHh6uRkdHq3/88Yd6+vRpUx0Zm9rz9ttvqx4eHuqvv/6qRkdHqz/99JPq7OysLlq0yFRHxqdmbNiwQX3ttdfUn3/+WQXUNWvWFDluqXG477771Hbt2qm7du1Sd+3apbZr104dPnx4TX3MOqus8UlJSVEHDRqkrlixQj1+/Li6e/du9e6771aDgoKKtFFT4yMBt4V0795dnTp1apGyVq1aqXPmzKmlHt2Zrly5ogLq9u3bVVVV1YKCAtXHx0d99913TXWys7NVNzc39bPPPlNVVftS2traqj/++KOpzoULF1SdTqf+/vvvNfsBbkNpaWlq8+bN1c2bN6v9+vUzBdwyNrXn5ZdfVvv06VPqcRmb2jVs2DD1qaeeKlIWEhKiPvbYY6qqyvjUllsDOkuNw9GjR1VA3bNnj6nO7t27VUA9fvx4NX+q20dJvxDdKiIiQgVMk6E1OT6ypMQCcnNziYyM5N577y1Sfu+997Jr165a6tWd6dq1awDUr18fgOjoaC5dulRkbAwGA/369TONTWRkJEajsUgdX19f2rVrJ+NnAc8++yzDhg1j0KBBRcplbGrPunXr6Nq1Kw899BDe3t507tyZL774wnRcxqZ29enThy1btnDy5EkADh48yM6dO7n//vsBGR9rYalx2L17N25ubtx9992mOj169MDNzU3GysKuXbuGoijUq1cPqNnxsbHMR7izJSQkkJ+fT4MGDYqUN2jQgEuXLtVSr+48qqoye/Zs+vTpQ7t27QBM//4ljU1MTIypjp2dHe7u7sXqyPhVzY8//sj+/fvZu3dvsWMyNrXn7NmzLFmyhNmzZ/Pqq68SERHB888/j8FgYPz48TI2tezll1/m2rVrtGrVCr1eT35+Pu+88w6PPvooIN8da2Gpcbh06RLe3t7F2vf29paxsqDs7GzmzJnD2LFjcXV1BWp2fCTgtiBFUYq8V1W1WJmoPs899xx//fUXO3fuLHasMmMj41c158+fZ8aMGWzatAl7e/tS68nY1LyCggK6du3K/PnzAejcuTNHjhxhyZIljB8/3lRPxqZ2rFixguXLl/P999/Ttm1boqKimDlzJr6+vkyYMMFUT8bHOlhiHEqqL2NlOUajkUceeYSCggI+/fTTcutXx/jIkhIL8PT0RK/XF/tN58qVK8V+8xXVY/r06axbt47Q0FD8/f1N5T4+PgBljo2Pjw+5ubkkJyeXWkdUXGRkJFeuXCEoKAgbGxtsbGzYvn07H330ETY2NqZ/WxmbmtewYUPatGlTpKx169bExsYC8r2pbS+++CJz5szhkUceoX379jz++OPMmjWLBQsWADI+1sJS4+Dj48Ply5eLtX/16lUZKwswGo08/PDDREdHs3nzZtPsNtTs+EjAbQF2dnYEBQWxefPmIuWbN2+mV69etdSrO4Oqqjz33HOsXr2arVu30rRp0yLHmzZtio+PT5Gxyc3NZfv27aaxCQoKwtbWtkid+Ph4Dh8+LONXBQMHDuTQoUNERUWZHl27dmXcuHFERUURGBgoY1NLevfuXSx95smTJwkICADke1PbMjMz0emK/ves1+tNaQFlfKyDpcahZ8+eXLt2jYiICFOd8PBwrl27JmNVRYXB9qlTp/jjjz/w8PAocrxGx8fs2ytFmQrTAv7nP/9Rjx49qs6cOVN1cnJSz507V9tdu60988wzqpubm7pt2zY1Pj7e9MjMzDTVeffdd1U3Nzd19erV6qFDh9RHH320xLRN/v7+6h9//KHu379fHTBggKTPqgY3ZylRVRmb2hIREaHa2Nio77zzjnrq1Cn1u+++Ux0dHdXly5eb6sjY1J4JEyaofn5+prSAq1evVj09PdWXXnrJVEfGp2akpaWpBw4cUA8cOKAC6sKFC9UDBw6YslxYahzuu+8+tUOHDuru3bvV3bt3q+3bt5e0gGYoa3yMRqM6cuRI1d/fX42KiioSI+Tk5JjaqKnxkYDbgv7973+rAQEBqp2dndqlSxdTajpRfYASH1999ZWpTkFBgfrGG2+oPj4+qsFgUO+55x710KFDRdrJyspSn3vuObV+/fqqg4ODOnz4cDU2NraGP83t79aAW8am9qxfv15t166dajAY1FatWqlLly4tclzGpvakpqaqM2bMUBs3bqza29urgYGB6muvvVYkSJDxqRmhoaEl/h8zYcIEVVUtNw6JiYnquHHjVBcXF9XFxUUdN26cmpycXEOfsu4qa3yio6NLjRFCQ0NNbdTU+Ciqqqrmz4cLIYQQQgghKkLWcAshhBBCCFGNJOAWQgghhBCiGknALYQQQgghRDWSgFsIIYQQQohqJAG3EEIIIYQQ1UgCbiGEEEIIIaqRBNxCCCGEEEJUIwm4hRB3nCeffBK9Xk9qaioABQUFuLm5MXr06Bq5fn5+Pv/4xz+46667sLOzQ1EUnnjiiRq5dk174oknUBSFbdu21XZXKm3btm0ljtGyZctQFIU333yzVvolhKg7bGq7A0IIUdP27dtH69atcXV1BeDYsWOkpqbSrVu3Grn+4sWL+ec//4mvry8hISHY29vTp0+fGrm2EEKImicBtxDijpKRkcGxY8eYMGGCqSw8PByA7t2710gf1q5dC0BYWBiBgYE1ck0hhBC1R5aUCCHuKPv37yc/P5+7777bVBYeHo6iKAQFBdVIH+Li4gAk2BZCiDuEBNxCiDvK3r17AYoF3K1atTItMamoo0ePMm7cOBo2bIidnR1+fn6MHz+eEydOFKlXuJ45OjoaAEVRTI9z586Zda0NGzYwePBg3N3dsbe3p2XLlsyZM4eUlJRidd98800URWHZsmVEREQwfPhwPDw8UBSFqKgoAKKionjppZcICgrCy8sLg8FAYGAg06ZN4+LFi6X2IzY2lueee47mzZtjb2+Ph4cH3bt3Z/78+WRlZZn1WdLT05k3bx7t27fH0dERV1dX+vXrZ/oLQEX973//Y/jw4Xh7e2MwGGjcuDF/+9vf+O2334rU++2333jqqadMy4qcnJzo2LEj8+fPJycnp1LXvpnRaOTzzz+ne/fueHp64ujoSJMmTRg+fDg//vhjldsXQtQ9sqRECHFb27ZtG8HBwcXKO3XqVKxMURQAAgICzA6At2zZwogRI8jKyqJLly7079+f48eP8+2337JmzRo2bNhA3759AUzrtFetWkVGRkaRZS3Ozs7lXmvBggW8+uqr2NjY0K9fPzw9Pfnzzz957733WLNmDTt27KBBgwbFztuxYweTJ0+mRYsW3HvvvVy8eBGdTptveffdd1m1ahXt2rWjd+/epmB8yZIlrF27ln379uHr61usvZEjR3Lt2jUCAwN54IEHyMjI4OjRo7z22muMHTuWJk2alPlZLl++zIABAzh69Ch+fn4MHjyYzMxMdu/ezahRo1iwYAFz5swp99+k0AsvvMDChQvR6/X07NkTf39/Ll68SGhoKCkpKQwbNsxUd+LEiWRkZNC2bVvat29PamoqERERvPbaa2zZsoVNmzah1+vNvvatHn/8cVasWIGnpye9evXC0dGRCxcuEBYWRnp6Oo888kil2xZC1FGqEELcxo4fP65OnDhRnThxovrUU0+piqKogYGBprJ+/fqpgHrfffeZyl5++WWz2k5PT1cbNGigAuqSJUuKHFu4cKEKqP7+/mp2dnaRYwEBAWpFf/xGRESoOp1OdXFxUcPDw03l2dnZ6kMPPaQC6kMPPVTknDfeeEMFVEB97733Smx3y5Yt6sWLF4uU5efnq2+99ZYKqE8++WSRY0lJSaqXl5cKqB9++KFaUFBQ5Pj27dvVlJQU0/sJEyaogBoaGlqk3tChQ1VAfemll9Tc3FxT+ZkzZ9S77rpL1ev16sGDB8v/h1FV9dtvvzX9W996Tnp6urply5YiZWvWrFHT09OLlKWmpqrDhw9XAfXrr78uciw0NFQF1AkTJhQp/+qrr1RAfeONN0xl0dHRKqB269ZNzcrKKlI/MzNT3bVrl1mfSQhxe5GAWwhxxzh48KAKqPPnzzeVvfTSSyqgnj9/vsLt/fe//1UBtW/fviUeDwoKUgH1hx9+KFJemYB7/PjxKqDOnTu32LHLly+rDg4Oqk6nU+Pi4kzlhQF3u3btigXG5vDz81Pr169fpOy9995TAXX48OFmtVFSwH3gwAEVUHv16lViv9auXasC6vTp0826RuvWrVVAXbVqlVn1S3Pq1CkVUENCQoqUVyTgDg8PVwF1xowZVeqLEOL2IktKhBB3jNDQUIAiS0y2bdtGYGAg/v7+FW4vLCwMgHHjxpV4/LHHHiMyMpKwsLAqLyMo61re3t7ce++9/PLLL+zatYuHHnqoyPERI0aYlsuUJDExkXXr1nH48GFSUlLIz88HtLXISUlJJCUlUb9+fQD++OMPAKZMmVLpz7J582YAHnjggRL7Vbj0pnC9fVkuXrzIsWPH8PDw4MEHHzS7D6dOnWLDhg2cPn2ajIwMCgoKUFXVdKyyWrVqhZOTE1999RVt27YlJCQEDw+PSrcnhLg9SMAthLhjhIaG4uzsTNeuXQHtpr39+/fz2GOPVaq9wpsKS1uvXFhe1s2HFbmWoigEBARU+FqNGzcutd0ffviByZMnk56eXmqdtLQ0U8B9/vx5AO666y5zu15M4fr4l19+mZdffrnUegkJCeW2VdH+qKrK3//+dz788ENTgH2rtLQ0s9oqiaurK1988QWTJ09m8uTJTJkyhZYtWxIcHMz48ePp0aNHpdsWQtRdEnALIW5by5Yt48knnyxWbmtrW6zesmXLAOjXr1+Fd0Usa/bYnOOWVNK17O3tS6wbExPDE088gaqqLFq0iGHDhuHn54eDgwMAvXr1Yvfu3SUGplX5TIUz6H379i0zNaKnp6fZbZrbnxUrVrBw4UL8/f1ZtGgRPXv2xMvLC1tbW3JzczEYDKUG4uZ69NFHGTRoEL/88gubNm1i+/btLFmyhCVLlvDiiy/y/vvvV6l9IUTdIwG3EOK21axZM1MmkCtXrvC///2PHj160LJlSwB2797NyZMnGTduHDY22o/DVq1amd1+YfaOwjR/t4qJiQGgYcOGlf4MN18rOjqamJgYU/+req0NGzaQm5vLCy+8wIwZM4odP3v2bLGyRo0acfz4cU6fPl2hf6ubFS7fGT16NM8//3yl2ri5PwCnT582q/6aNWsAWLJkCcOHDy9yrKTPW1leXl5MmjSJSZMmoaoqGzduZMyYMXzwwQc88cQTtGnTxmLXEkJYP8nDLYS4bfXp08c0e/3AAw8A8P7775vKvL29ady4McuXLzeVVSQVXWG6v++++67E44XlhfWqoqxrXb16lU2bNqHT6ejVq5fZbSYnJwM3gtab7dixg8uXLxcrHzRoEABLly41+zqltVHZfNs38/X1pXXr1iQmJrJ69epy65f1mVeuXFnl/pREURTuu+8+U2rCw4cPV8t1hBDWSwJuIcQdYceOHdjb25u2b8/Ozmbv3r3cc889lW7z4YcfpkGDBoSFhRULQD/66CP27t2Lv78/o0aNqlLfAZ599ll0Oh2LFy9m3759pvLc3FymT59OZmYmISEh+Pn5md1mixYtAFi+fDkZGRmm8gsXLjB16tQSz5k0aRKenp6sX7+eTz75pNjyi7CwMK5du1bmdXv06MHAgQMJDQ1l1qxZxdaPFxQUsGnTJnbu3GnW5yj8JWnmzJkcOXKkyLGMjAy2bt1qel/4mZcuXVqk72FhYXzwwQdmXa8sBw4cYPXq1RiNxiLlycnJhIeHA2WvqRdC3J4k4BZC3BHCwsLo3r07BoMB0HaXzMnJqVLA7eTkxHfffYeDgwNTpkyha9eujB07li5dujBjxgycnJz4/vvvTdesiu7du/PPf/6T1NRUevbsyeDBg3n00Udp1qwZK1asoHnz5nzyyScVanPkyJG0bduWffv20axZM0aPHs3w4cNp0aIF7u7uJc6W169fn5UrV+Li4sL06dNp3rw5Y8aMYcSIEQQGBnLPPfeYZpHL8t1339GhQwcWLVpEQEAAAwcO5JFHHqFv3774+PgwZMiQIr9YlGX8+PE899xznD9/no4dO3LPPfcwduxY+vfvj6+vL/PmzTPVff7553FycuLTTz+lXbt2PProo9xzzz3069ev1F8yKiImJoYHH3wQLy8vBg0axGOPPcbw4cNp0qQJZ8+eZdSoUXLjpBB3IAm4hRC3vejoaM6fP18kuN6xYwdAlQJugIEDB7J3714effRR4uLiWLVqFZcuXTKlBLTEcpJCr776Kr/++iv9+vVj7969rF69GoPBwEsvvUR4eHiJu0yWxc7OjrCwMJ555hns7e359ddfOXbsGNOnT2fz5s3Fbi4tFBwcTFRUFJMnTyYvL4+1a9eyZ88evL29WbBgAT4+PuVeu0GDBuzZs4eFCxfSvHlz9u7dy9q1a4mLi6Nz5878+9//rlD2mI8//pg1a9YwcOBADh8+zM8//0x0dDQDBw4skgmlRYsW7N27lxEjRpCQkMC6detIT0/n888/t8gMd48ePXj77bcJCgrixIkT/PTTT+zbt48OHTrw9ddfV9uyFSGEdVPUqt6OLYQQQgghhCiVzHALIYQQQghRjSTgFkIIIYQQohpJwC2EEEIIIUQ1koBbCCGEEEKIaiQBtxBCCCGEENVIAm4hhBBCCCGqkQTcQgghhBBCVCMJuIUQQgghhKhGEnALIYQQQghRjSTgFkIIIYQQohpJwC2EEEIIIUQ1koBbCCGEEEKIaiQBtxBCCCGEENXo/wGD4RICwU2OSwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams['figure.figsize'] = (8.0, 6.0)\n",
    "plt.semilogy(oracle_calls11,error11,'r-o',label = 'PRAGDA')\n",
    "plt.semilogy(oracle_calls12,error12,'b-d',label = 'iMCN')   \n",
    "plt.semilogy(oracle_calls13,error13,'y-s',label = 'GDA')  \n",
    "plt.semilogy(oracle_calls14,error14,'g--*',label = 'MCN')  \n",
    "plt.semilogy(oracle_calls15,error15,'m-.^',label = 'LMCN') \n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.xlabel('# of oracle calls',fontsize = 15)\n",
    "plt.xlim(0, 1200)\n",
    "plt.ylabel('log of error',fontsize = 15)\n",
    "plt.savefig('pragda3.pdf')\n",
    "plt.show(block=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6734493-f77c-480d-829c-5c090c80aa48",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91b8330b-87aa-42dd-8e9b-836f958a1f21",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef6053c3-a3a5-4696-bd00-b2b6c04dc4e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "678311e2-d1b8-4ae7-ac97-159b0405f8fe",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
