{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "seIhLShNHsjI"
   },
   "source": [
    "# Feedback Alignment\n",
    "\n",
    "The goal of this notebook is to do experiments on Feedback Alignment. \n",
    "The experiment we want to do is on deep linear autoencoder.\n",
    "\n",
    "The code is borrowed from Gidel, G., Bach, F., and Lacoste-Julien, S. *Implicit regularization of discrete gradient dynamics in linear neural networks*, (2019) , with the constent of the author."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "qj5RbcEiHsjQ"
   },
   "source": [
    "We draw from a low dimensional gaussian. \n",
    "$$\n",
    "x \\sim A z + \\epsilon \\quad \\text{where} \\quad z \\sim \\mathcal{N}(0,I_h),\\ \\epsilon \\sim 10^{-3} \\mathcal{N}(0,I_d)\n",
    "$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "Lbm3FTBqHsjR"
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import seaborn as sns\n",
    "# from matplotlib import rc\n",
    "import matplotlib.pylab as plt\n",
    "# import os\n",
    "# print(os.environ['PATH'])\n",
    "\n",
    "np.random.seed(2)\n",
    "sns.set(font_scale=1.5)\n",
    "# rc('font', **{'family': 'serif', 'serif': ['Computer Modern']})\n",
    "# rc('text', usetex=True)\n",
    "\n",
    "#sns.despine()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "pch9ocu4H8k7"
   },
   "outputs": [],
   "source": [
    "! sudo apt-get install texlive-latex-recommended \n",
    "! sudo apt-get install dvipng texlive-latex-extra texlive-fonts-recommended  \n",
    "! wget http://mirrors.ctan.org/macros/latex/contrib/type1cm.zip \n",
    "! unzip type1cm.zip -d /tmp/type1cm \n",
    "! cd /tmp/type1cm/type1cm/ && sudo latex type1cm.ins\n",
    "! sudo mkdir /usr/share/texmf/tex/latex/type1cm \n",
    "! sudo cp /tmp/type1cm/type1cm/type1cm.sty /usr/share/texmf/tex/latex/type1cm \n",
    "! sudo texhash "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "ijQDY4wWIfNT"
   },
   "outputs": [],
   "source": [
    "!apt install cm-super"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "nPj150CUHsjS"
   },
   "outputs": [],
   "source": [
    "h = 5\n",
    "p = 20\n",
    "d = 20\n",
    "n = 1000\n",
    "A = 1./np.sqrt(d) * np.random.rand(h,d)\n",
    "epsilon = 10**(-3)\n",
    "#D = np.diag([1./(k+1)**2 for k in range(p)])\n",
    "D = np.diag([2**(-k+2) for k in range(h)])\n",
    "U = np.random.multivariate_normal(np.zeros(h),D, size = n)\n",
    "X = np.dot(U,A) +  epsilon * np.random.multivariate_normal(np.zeros(d),np.eye(d), size = n)\n",
    "Sigma = A.T.dot(D).dot(A)\n",
    "diag,u= np.linalg.eigh(Sigma) # diag = ev's, u = e.vectors\n",
    "u = np.flip(u,axis=1)\n",
    "# print(u.shape)\n",
    "diag = diag[::-1] #order from biggest to smallest\n",
    "I_p   = np.eye(d)\n",
    "I_p[h:d,h:d] = 0\n",
    "Target = np.dot(u,I_p) #keep only dominant h=5 e.vectors\n",
    "Target = Target.dot(Target.T)\n",
    "C = np.cov(X.T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "B__STNgKHsjS",
    "outputId": "9acbdea5-a68d-4490-f829-4f8daea1da55"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.4965004699960878e-05"
      ]
     },
     "execution_count": 33,
     "metadata": {
      "tags": []
     },
     "output_type": "execute_result"
    }
   ],
   "source": [
    "1./n * np.sum((np.dot(X,np.eye(d)-Target))**2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "pv_O4_fQHsjT"
   },
   "source": [
    "We want to minimize the following objective: \n",
    "$$ \n",
    "\\min_{W_1,W_2} f(W_1,W_2) := \\frac{1}{2n}\\| X - XW_1 W_2\\|_2^2\n",
    "$$\n",
    "The gradient respect to $W_1$ and $W_2$ are, \n",
    "\\begin{align}\n",
    "&\\nabla_{W_2} f(W_1,W_2) =  -W_1^\\top   (X^\\top X-X^\\top X W_1 W_2) \\\\ \n",
    "&\\nabla_{W_1} f(W_1,W_2) =   -(X^\\top X-X^\\top X W_1 W_2) W_2^\\top\n",
    "\\end{align}\n",
    "$W_1$ is the first layer, $W_2$ is is the second one. The FA matrix $F$ will be sampled randomly: $F_{ij} \\sim \\mathcal{U}([0,1])$. The corresponding FA equations are\n",
    "\\begin{align}\n",
    "&\\nabla_{W_2} f(W_1,W_2) =  -W_1^\\top  (X^\\top X-X^\\top X W_1W_2) \\\\ \\\n",
    "&\\nabla_{W_1} f(W_1,W_2) =   -(X^\\top X-X^\\top X W_1 W_2) F\n",
    "\\end{align}\n",
    "If we want to minimize directly respect to $W:= W_1W_2$ (i.e. $1$-layer network) we get \n",
    "$$ \n",
    "\\min_W f(W) := \\frac{1}{2n}\\| X - XW\\|_2^2\n",
    "$$\n",
    "with the following gradient \n",
    "$$\n",
    "\\nabla f(W) = - X^\\top X (I_d - W)\n",
    "$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "lWOe04MZHsjU"
   },
   "outputs": [],
   "source": [
    "### gradient updates, 2 layers ###\n",
    "def gradient_W2(N,M,C): ## GD ##\n",
    "    A = np.dot(N,M)\n",
    "    I = np.eye(d)\n",
    "    return -np.dot(N.T.dot(C), I - A)\n",
    "def gradientFA_W2Euler(N,M,C): ## FA (Euler method) ##\n",
    "    A = np.dot(N,M)\n",
    "    I = np.eye(d)\n",
    "    return -np.dot(N.T.dot(C), I - A)\n",
    "def gradientFA_W2(Nold,Nnew,M,C): ## FA (midpoint method) ##\n",
    "    A = np.dot(Nold,M)\n",
    "    I = np.eye(d)\n",
    "    Nmid = 1/2*(Nold+Nnew)\n",
    "    return -np.dot(Nmid.T.dot(C), I - A)\n",
    "\n",
    "\n",
    "\n",
    "def gradient_W1(N,M,C): ## GD ##\n",
    "    A = np.dot(N,M)\n",
    "    I = np.eye(d)\n",
    "    return -np.dot(C, (I - A).dot(M.T))\n",
    "def gradientFA_W1(N,M,F,C): ## FA ##\n",
    "    A = np.dot(N,M)\n",
    "    I = np.eye(d)\n",
    "    # F = np.eye(d)\n",
    "    return -np.dot(C, (I - A).dot(F))\n",
    "\n",
    "\n",
    "### gradient updates, 1 layer ###\n",
    "def gradient_A(A,C): ## GD ##\n",
    "    I = np.eye(d)\n",
    "    return -C.dot(I-A)\n",
    "\n",
    "def obj_value(A,C):\n",
    "    Diff = np.eye(d) - A\n",
    "    return .5 / np.sqrt(n) * np.trace(Diff.dot(C.dot(Diff)))\n",
    "\n",
    "def reconstruction(Iterate,Target):\n",
    "    (d,r) = Iterate.shape\n",
    "    if r==d:\n",
    "        return np.sum((Iterate - Target)**2)\n",
    "    else:\n",
    "        return np.sum((Iterate.dot(Iterate.T) - Target)**2)\n",
    "        "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "EtA6Y4Lf_g2x"
   },
   "source": [
    "\n",
    "In the $3$-layer case, \n",
    "$$ \n",
    "\\min_{W_1,W_2,W_3} f(W_1,W_2,W_3) := \\frac{1}{2n}\\| X - XW_1 W_2W_3\\|_2^2\n",
    "$$\n",
    "the GD dynamics becomes (see Gidel *et al*, '19): \n",
    "\\begin{align}\n",
    "&\\nabla_{W_3} f(W_1,W_2,W_3) =  -W_2^\\top W_1^\\top   (X^\\top X-X^\\top X W_1 W_2W_3) \\\\ \n",
    "&\\nabla_{W_2} f(W_1,W_2,W_3) =  -W_1^\\top   (X^\\top X-X^\\top X W_1 W_2W_3)W_3^\\top \\\\ \n",
    "&\\nabla_{W_1} f(W_1,W_2,W_3) =   -(X^\\top X-X^\\top X W_1 W_2W_3) W_3^\\top W_2^\\top\n",
    "\\end{align}\n",
    "while the FA dynamics is:\n",
    "\\begin{align}\n",
    "&\\nabla_{W_3} f(W_1,W_2,W_3) =  -W_2^\\top W_1^\\top  (X^\\top X-X^\\top X W_1W_2W_3) \\\\ \n",
    "&\\nabla_{W_2} f(W_1,W_2,W_3) =  -W_1^\\top  (X^\\top X-X^\\top X W_1W_2W_3)F_2 \\\\ \n",
    "&\\nabla_{W_1} f(W_1,W_2,W_3) =   -(X^\\top X-X^\\top X W_1 W_2W_3) F_1\n",
    "\\end{align}\n",
    "with FA matrices sampled randomly: $F_{1;ij}, F_{2;ij} \\sim \\mathcal{U}([0,1])$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "ySvpCqfBFFSp"
   },
   "outputs": [],
   "source": [
    "### gradient updates, 3 layers ###\n",
    "# N = W1, M = W2, P = W3\n",
    "def gradient3_W3(N,M,P,C): ## GD ##\n",
    "    A = np.dot(N,M)\n",
    "    B = np.dot(A,P)\n",
    "    I = np.eye(d)\n",
    "    return -np.dot(A.T.dot(C), I - B)\n",
    "\n",
    "def gradient3_W2(N,M,P,C): ## GD ##\n",
    "    A = np.dot(N,M)\n",
    "    B = np.dot(A,P)\n",
    "    I = np.eye(d)\n",
    "    return -np.dot(N.T.dot(C), I - B).dot(P.T)\n",
    "def gradientFA3_W2(N,M,P,F,C): ## FA ##\n",
    "    A = np.dot(N,M)\n",
    "    B = np.dot(A,P)\n",
    "    I = np.eye(d)\n",
    "    return -np.dot(N.T.dot(C), I - B).dot(F)\n",
    "\n",
    "\n",
    "def gradient3_W1(N,M,P,C): ## GD ##\n",
    "    A = np.dot(N,M)\n",
    "    B = np.dot(A,P)\n",
    "    D = np.dot(M,P)\n",
    "    I = np.eye(d)\n",
    "    return -np.dot(C, (I - B).dot(D.T))\n",
    "def gradientFA3_W1(N,M,P,F,C): ## FA ##\n",
    "    A = np.dot(N,M)\n",
    "    B = np.dot(A,P)\n",
    "    I = np.eye(d)\n",
    "    return -np.dot(C, (I - B).dot(F))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "ay4IEm84HsjU"
   },
   "outputs": [],
   "source": [
    "def FA_f(M_0= None,N_0=None,F=None,stepsize = 1e-6,niter = 1000):\n",
    "    M = np.copy(M_0)\n",
    "    N = np.copy(N_0) \n",
    "    l_obj_value = [obj_value(N.dot(M),C)]\n",
    "    l_trace_norm = [np.trace(N.dot(M))]\n",
    "    l_resconstruct = [reconstruction(N.dot(M),Target)]\n",
    "    for t in range(niter):\n",
    "        # Nold = np.copy(N)\n",
    "        grad_N = gradientFA_W1(N,M,F,C)\n",
    "        # Nnew = Nold - stepsize * grad_N\n",
    "        # N = Nnew\n",
    "\n",
    "        # grad_M = gradientFA_W2(Nold,Nnew,M,C)\n",
    "        grad_M = gradientFA_W2Euler(N,M,C)\n",
    "        N -= stepsize * grad_N\n",
    "        M -= stepsize * grad_M\n",
    "        l_obj_value.append(obj_value(N.dot(M),C))\n",
    "        l_trace_norm.append(np.trace(N.dot(M)))\n",
    "        l_resconstruct.append(reconstruction(N.dot(M),Target))\n",
    "    return (l_obj_value,l_trace_norm,l_resconstruct)\n",
    "\n",
    "\n",
    "def FA3_f(M_0= None,N_0=None,P_0=None,F1=None,F2=None,stepsize = 1e-6,niter = 1000):\n",
    "    N = np.copy(N_0)\n",
    "    M = np.copy(M_0)\n",
    "    P = np.copy(P_0)\n",
    "    l_obj_value = [obj_value(np.dot(N.dot(M),P),C)]\n",
    "    l_trace_norm = [np.trace(np.dot(N.dot(M),P))]\n",
    "    l_resconstruct = [reconstruction(np.dot(N.dot(M),P),Target)]\n",
    "    for t in range(niter):\n",
    "        grad_N = gradientFA3_W1(N,M,P,F1,C)\n",
    "        grad_M = gradientFA3_W2(N,M,P,F2,C)\n",
    "        grad_P = gradient3_W3(N,M,P,C)\n",
    "        N -= stepsize * grad_N\n",
    "        M -= stepsize * grad_M\n",
    "        P -= stepsize * grad_P\n",
    "        l_obj_value.append(obj_value(np.dot(N.dot(M),P),C))\n",
    "        l_trace_norm.append(np.trace(np.dot(N.dot(M),P)))\n",
    "        l_resconstruct.append(reconstruction(np.dot(N.dot(M),P),Target))\n",
    "    return (l_obj_value,l_trace_norm,l_resconstruct)\n",
    "\n",
    "\n",
    "def GD_f(M_0= None,N_0=None,stepsize = 1e-6,niter = 1000):\n",
    "    M = np.copy(M_0)\n",
    "    N = np.copy(N_0)\n",
    "    l_obj_value = [obj_value(N.dot(M),C)]\n",
    "    l_trace_norm = [np.trace(N.dot(M))]\n",
    "    l_resconstruct = [reconstruction(N.dot(M),Target)]\n",
    "    for t in range(niter):\n",
    "        grad_M = gradient_W2(N,M,C)\n",
    "        grad_N = gradient_W1(N,M,C)\n",
    "        N -= stepsize * grad_N\n",
    "        M -= stepsize * grad_M\n",
    "        l_obj_value.append(obj_value(N.dot(M),C))\n",
    "        l_trace_norm.append(np.trace(N.dot(M)))\n",
    "        l_resconstruct.append(reconstruction(N.dot(M),Target))\n",
    "    return (l_obj_value,l_trace_norm,l_resconstruct)\n",
    "\n",
    "def GD3_f(M_0= None,N_0=None,P_0=None,stepsize = 1e-6,niter = 1000):\n",
    "    N = np.copy(N_0)\n",
    "    M = np.copy(M_0)\n",
    "    P = np.copy(P_0)\n",
    "    l_obj_value = [obj_value(np.dot(N.dot(M),P),C)]\n",
    "    l_trace_norm = [np.trace(np.dot(N.dot(M),P))]\n",
    "    l_resconstruct = [reconstruction(np.dot(N.dot(M),P),Target)]\n",
    "    for t in range(niter):\n",
    "        grad_N = gradient3_W1(N,M,P,C)\n",
    "        grad_M = gradient3_W2(N,M,P,C)\n",
    "        grad_P = gradient3_W3(N,M,P,C)\n",
    "        N -= stepsize * grad_N\n",
    "        M -= stepsize * grad_M\n",
    "        P -= stepsize * grad_P\n",
    "        l_obj_value.append(obj_value(np.dot(N.dot(M),P),C))\n",
    "        l_trace_norm.append(np.trace(np.dot(N.dot(M),P)))\n",
    "        l_resconstruct.append(reconstruction(np.dot(N.dot(M),P),Target))\n",
    "    return (l_obj_value,l_trace_norm,l_resconstruct)\n",
    "\n",
    "\n",
    "\n",
    "def GD_g(A_0=None,stepsize = 1e-6,niter = 1000): ## 1-layer NN training ##\n",
    "    A = np.copy(A_0)\n",
    "    l_obj_value = [obj_value(A,C)]\n",
    "    l_trace_norm = [np.trace(A)]\n",
    "    l_resconstruct = [reconstruction(A,Target)]\n",
    "    for t in range(niter):\n",
    "        grad_A = gradient_A(A,C)\n",
    "        A -= stepsize * grad_A\n",
    "        l_obj_value.append(obj_value(A,C))\n",
    "        l_trace_norm.append(np.trace(A))\n",
    "        l_resconstruct.append(reconstruction(A,Target))\n",
    "    return (l_obj_value,l_trace_norm,l_resconstruct)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "9xNCeRLeHsjV"
   },
   "outputs": [],
   "source": [
    "niter = 1000 #(to do 10^6 iterations)\n",
    "nexp = 5\n",
    "\n",
    "# M_0 = np.zeros((p,d))\n",
    "# N_0 = np.zeros((p,d))\n",
    "\n",
    "M_0 = 10**-5 * 1/np.sqrt(d) * np.random.rand(p,d) \n",
    "N_0 = 10**-5 * 1/np.sqrt(d) * np.random.rand(p,d)  #M_0.dot(M_0)\n",
    "P_0 = 10**-5 * 1/np.sqrt(d) * np.random.rand(p,d) \n",
    "\n",
    "dataFA2 = []\n",
    "objFA2 = []\n",
    "traceFA2 = []\n",
    "reconstFA2 = []\n",
    "\n",
    "dataFA3 = []\n",
    "objFA3 = []\n",
    "traceFA3 = []\n",
    "reconstFA3 = []\n",
    "\n",
    "for idx in range(nexp):\n",
    "  F_0 = 1/np.sqrt(d)*np.random.rand(p,d)\n",
    "  # F_0 = np.diag(np.random.randint(1,5, size=d))\n",
    "\n",
    "  # F1 = np.diag(np.random.randint(1,5, size=d)) \n",
    "  # F2 = np.diag(np.random.randint(1,5, size=d)) \n",
    "\n",
    "  F1 = 1/np.sqrt(d)*np.random.rand(p,d)\n",
    "  F2 = 1/np.sqrt(d)*np.random.rand(p,d)\n",
    "\n",
    "  # if np.linalg.det(F_1) or np.linalg.det(F_2) == 0:\n",
    "  #   print('det(F)=0')\n",
    "\n",
    "  ## FA, 2 layers ##\n",
    "  (l_obj_MFA2,l_trace_MFA2,l_reconstruct_MFA2) = FA_f(niter = niter,M_0=M_0,N_0=N_0,F=F_0,stepsize = .01)\n",
    "\n",
    "  ## FA, 3 layers ##\n",
    "  (l_obj_MFA3,l_trace_MFA3,l_reconstruct_MFA3) = FA3_f(niter = niter,M_0=M_0,N_0=N_0,P_0=P_0,F1=F1,F2=F2,stepsize = .01)\n",
    "  \n",
    "  objFA2.append(l_obj_MFA2)\n",
    "  traceFA2.append(l_trace_MFA2)\n",
    "  reconstFA2.append(l_reconstruct_MFA2)\n",
    "  \n",
    "  objFA3.append(l_obj_MFA3)\n",
    "  traceFA3.append(l_trace_MFA3)\n",
    "  reconstFA3.append(l_reconstruct_MFA3)\n",
    "\n",
    "  dataFA2.append(dict(name = r'$FA$2' + str(idx),x= np.array(range(niter+1)),obj= l_obj_MFA2,trace = l_trace_MFA2, reconst = l_reconstruct_MFA2))\n",
    "  dataFA3.append(dict(name = r'$FA$3' + str(idx),x= np.array(range(niter+1)),obj= l_obj_MFA3,trace = l_trace_MFA3, reconst = l_reconstruct_MFA3))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "-IJ6ZnqsSs-M"
   },
   "outputs": [],
   "source": [
    "# print(len(objFA))\n",
    "# print(len(objFA[0]))\n",
    "\n",
    "## 2 layers ##\n",
    "mean_obj2 = np.mean(np.array(objFA2), axis=0)\n",
    "std_obj2 = np.std(np.array(objFA2), axis=0)\n",
    "\n",
    "mean_trace2 = np.mean(np.array(traceFA2), axis=0)\n",
    "std_trace2 = np.std(np.array(traceFA2), axis=0)\n",
    "\n",
    "mean_rec2 = np.mean(np.array(reconstFA2), axis=0)\n",
    "std_rec2 = np.std(np.array(reconstFA2), axis=0)\n",
    "\n",
    "\n",
    "## 3 layers ##\n",
    "mean_obj3 = np.mean(np.array(objFA3), axis=0)\n",
    "std_obj3 = np.std(np.array(objFA3), axis=0)\n",
    "\n",
    "mean_trace3 = np.mean(np.array(traceFA3), axis=0)\n",
    "std_trace3 = np.std(np.array(traceFA3), axis=0)\n",
    "\n",
    "mean_rec3 = np.mean(np.array(reconstFA3), axis=0)\n",
    "std_rec3 = np.std(np.array(reconstFA3), axis=0)\n",
    "\n",
    "\n",
    "# plt.semilogx(mean_obj)\n",
    "# plt.fill_between(np.array(range(niter+1)), mean_obj - std_obj, mean_obj + std_obj,alpha = 0.5)\n",
    "# plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "FVEb7aLEsSV1"
   },
   "outputs": [],
   "source": [
    "## GD, 2 layers ##\n",
    "(l_obj_MGD2,l_trace_MGD2,l_reconstruct_MGD2) = GD_f(niter = niter,M_0=M_0,N_0=N_0,stepsize = .01)\n",
    "\n",
    "\n",
    "## GD, 3 layers ##\n",
    "(l_obj_MGD3,l_trace_MGD3,l_reconstruct_MGD3) = GD3_f(niter = niter,M_0=M_0,N_0=N_0,P_0=P_0,stepsize = .01)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "1ao3Rwf_HsjV"
   },
   "outputs": [],
   "source": [
    "## GD, 1-layer ##\n",
    "A_0 = np.dot(N_0.dot(M_0), P_0)\n",
    "(l_obj_A,l_trace_A,l_reconstruct_A) = GD_g( A_0 = A_0, niter = niter,stepsize = .01) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 300
    },
    "id": "C93VotGDHsjV",
    "outputId": "f47c203d-32c8-42b0-a6b6-54e1be19557d"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAaEAAAEbCAYAAABz+TvRAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOy9eXzU1b3///wss2aykYWwJAESVtlEEHCtxSqiKC7Y1haVX6tyrdXqtaVo78VWi1WpYm2t1614Kf4qIKItIEVUBLwuRWUpiyRhDySTdTL78vl8/5hkICYhC0kmmc95PtoHzlk+n/eZT2Zec855n/db0nVdRyAQCASCOCDH2wCBQCAQGBchQgKBQCCIG0KEBAKBQBA3hAgJBAKBIG4IERIIBAJB3BAiJBAIBIK4IURIIBAIBHFDjbcBvY3qag+aZuyjVRkZDior3fE2Q/ANxHPpeYhnArIskZ6e1GK9EKF2omm64UUIEO9BD0U8l56HeCZnRizHCQQCgSBuCBESCAQCQdwQIiQQCASCuCFESCAQCARxQ4iQQCAQCOKG8I5rJyePlxAMBpuUSwCS1EIvqdE/jWoalbXym0A+1bjZW0kKSAqS3Mx1JKnZ+3/DwubrpMY3DFFHdbXnjD1lGZTT7WjxvWnt7q1Xn/nabeBs+rfSVzpb29qB4o1QEzC2O3BPI5GeSbLJgSIrnX5dIULtxPfc8wTKnfE2I67UxNuABCEiQV2STGWayr5BVopyLWcvqAJBFzGl30TmjLy5068rRKidlI7oiyfH1KRcau0oQKtHBdp7lkBv8lJCR0IHvf7f2H9r9f+CpGtRe9GQdA0ZDUnTkL9xPR0IyyYispmgYiekOAjLFkBCUSUiYf0brRuj6TqRiE5E09E0jXBEJxjSCGvR+yuSRFqymf4ZSZjVln9dSa29L2d7BONscjqeZT5IKRzBWlPHoKMnKdjqwn9OAXU3Xg5Kx1bJHclW3HX+s7JJ0Lkk0jMpTB/SJdeV4plZNRgM8uyzz/L222/jcrkYMWIE999/P1OnTm21b1lZGYsWLWLbtm1omsaUKVNYsGABubm5sTY1NTU8/vjj7Ny5k5MnTyLLMoMGDWLOnDlcd911HVoqqax0J+ThMz0cQHdXodWdRHedRK86iFZ1hHBNFXoguvwo26yYB51D5vlXUWseAlL7vyw9/hCf7yvn410nKDruwmZRuPnbhVw8tj+yQWcBuqZRvWE9FW+uJPOGm+gz45oOXScrKxmns66TrROcDeKZRCMmZGQ4WqyPqwg98MAD/POf/+TWW28lPz+ft956i927d7Ns2TLOPffcFvt5PB5uuOEGPB4Pt99+O6qqsnTpUiRJYs2aNaSmpgJw7NgxfvGLXzBx4kT69euHpml8/PHHvPfee9x9993cd9997bY5UUWoJXRdR686SOTodiIHPyPkjC5FmrIysYyfjpR/KchNZ4ZtYVdJJS//Yw8eX5ibvjWEK87PM6wQARz/47P49u9jyOIlyBZLu/uLL7yeh3gmPViEdu7cyezZs1mwYAG33347AIFAgGuuuYbs7GyWL1/eYt+XXnqJ3//+96xevZpRo0YBUFxczMyZM7nrrrtaFZd58+bx2WefsX379nbPhowmQt9Edx3FVLyBmq8+QQ+FMffri2Xq9yFjXIf2M0orPTz1+pf4AmHuuvYczh2W1QVW9w68X+/n2JOPk/PjO0mZckG7+4svvJ6HeCati1DcXLTfffddTCYTs2fPjpVZLBZuuukmtm/fTnl5eYt9N2zYwPjx42MCBFBQUMDUqVNZv359q/ceMGAAPp+PUCh0doMwIFJKLulX3I/je49jGzmWYFk57neeQ9+1FCKeVvt/k/4ZSfzompFous6bH5VQ6w50vtG9BFvhUBRHMp5/7463KQJBtxE3Edq7dy+DBw8mKalxdNWxY8ei6zp79+5ttp+maezfv5/Ro0c3qRszZgyHDh3C5/M1Kg8EAlRVVXHs2DHWrFnD6tWrOe+88zCbzZ03IKNhy0K96H6SZ9yJYrfh/mQzkS2/h0BFuy91zqA+nD+yL6UVHj786jhxXCGOK5IsYxsxEt++ffE2RSDoNuImQk6nk+zs7CblWVnR5ZiWZkI1NTUEg8FYu2/21XUdp7OxC/XKlSuZOnUq06ZNY/78+YwbN47Fixd3wigMjiRB/6nYZv4Sy4C+eL8uIbzlWST/iXZeRuLaCwdjMyt8uqeMGnfTc1hGwTpoEOHqKiLuxDhbIhC0RtxctP1+PyZT0w1tS/2GbCDQ/LJMQ3lzs5iGvn5/Y5fIyy+/nCFDhlBdXc2HH36I0+lsMltqK2da2zQSWVnJp70Yif6931Cx5jHqio9itb1M+vQHwdr0R0ZLZGY6mDiyL1t2lHLI6WHYkMwusLrno54zjIpVYPNUkTq4X7v7N3ough6BeCZnJm4iZLVam92TaRAZSwveQQ3lzUUtaOhrtVoblefk5JCTkwPA1VdfzSOPPMLcuXN59913m7RtDaM7JkBLm60WuPBuLL5nqP53MRHLn2D8Xehq2z+AF4zuy9adpbz/+RFGDUzFYu7809k9nVBSHwDK9xQR7JvXrr5iE7znIZ5JD3ZMyMrKanbJrWEprbmlOoC0tDTMZnOTJbeGvpIkNbtUdzpXXnklJ06c4PPPP++A5YIWsfbDcsmPUFMduHbsRT78D9DCbe6e3zeZnD52jpTVUZ0gB/zai5qWBopCqLL9e2sCQW8kbiI0YsQIDh48iMfT2KNqx44dsfrmkGWZYcOGsXt3Uw+inTt3kp+fj81mO+O9G2ZMdXXG/oXSFejJw0i6YAaSBO4v/g+5dkeb+1rNKkMHpFLnDbH3cHUXWtlzkWQZU58+hKuq4m2KQNAtxE2Epk+fTigUYuXKlbGyYDDI6tWrmTBhAn379gWgtLSU4uLiRn2vvPJKvvrqK/bs2RMrKykp4ZNPPmH69OmxsqoWPsirVq1CkiTOOeeczhySAECS0Pp/m6RzhhOudhHZ/Q+kYGWbu08cEZ3F7j1cTTiidZWVPRq1T4aYCQkMQ9z2hMaNG8f06dNZvHgxTqeTvLw83nrrLUpLS3n88cdj7ebPn89nn33G/v37Y2W33HILK1eu5M4772Tu3LkoisLSpUvJysqKHXwFWL58Oe+99x7f+ta3GDBgALW1tWzcuJEdO3Zwyy23kJ+f351DNg6KFXn0TZiO/QFP0VHSBn9IeMANbTrMmts3hWS7iZNVPjy+EKmO9kcO6O2YMjLwtnBEQSBINOIawPTJJ59kyZIlvP3229TW1jJ8+HBefPFFzjvvvDP2czgcLFu2jEWLFvH888+jaRqTJ0/m4YcfJj09PdZu6tSp7Nu3jzVr1lBZWYnJZGL48OH89re/5cYbb+zq4Rka3T4Y27jzcb3/T/y7P8ecMQnN1vpGe5JVpW96/b6QO2BIEVJSUonUudB1vVtTQQgE8SCuseN6I8I7ru0eP1KgjOCmp/EfLyd92rcID57TpqCnyzd+zabtx/jhd4bx7fMGdobJvYqqDeupWPkGhX/8M7L1zPubpyM8sXoe4pn0YO84QeKjW/piGTkRAP+Bfci+o23qN3RANADtwZMuNAP+RlIc0Q9sWDjOCAyAECFBl6L3vwRL/yx8R8uQnR+3KQfPoH7JqIpERY0PfyDSDVb2LJTk6NmqSJ2ImiBIfIQICboU3ZyNbego0DQCB/cjBVsOTNuAw2amT4qVSlcAf7Dt54wSBcVRL0JuV5wtEQi6HiFCgq5FktAHXIypTyr+oydR6lqPEG01K6Q7zNS6g9T5jBdH7tRMSCzHCRIfIUKCLkez5WHLH4jm8xM5/EWrKR9kWSI73U4oonHc2f70EL0dxR6NLK95vXG2RCDoeoQICboe2YQ8ZAqSyUTgeBlKGxwUBmZFN+ePlRtvX0Suj2eo+Y0ZukhgLIQICboFzTEcS/9MAuVVyFVftuqgMKhfdEnKWesnohkrcoKkKEhmM1oHI70LBL0JIUKCbkE3Z2HJzQdNI3isGCl85thwGSlWLCaZOk+QQNBYIgQg22xofiFCgsRHiJCge5Ak6H8+ss1K4GQlsu/YGZubTQrJdjMub4hAyHhu2rLVJmZCAkMgREjQbej2PCw5GYQqa5Brdp1xSc5iUki2m6jzBg3ppi3bbER8Yk9IkPgIERJ0G7qpD+b+/UHXCZUeRgrXttjWpMqkOix4/GFcHuO5actWq1iOExgCIUKC7kOSkfqfh2QxE3RWIwfKztg8MyUavPRklfFclWWbWI4TGAMhQoJuRbflYc5II1hZi+QpOmPbzNRo8M6KWuN9GStW4ZggMAZChATdimbOxJyZjh4MojuLINLyvkdWWvS8THVdEKMFe5dtVjSxJyQwAEKEBN2LbEYZEE3dHqqoRg61nHU1O90OgMcfIhQ2lpu2ZLagBwPxNkMg6HKECAm6n/SRKMlJBCtrkf3HW2xmt5qwmBS8/jBBg4mQbDajh8PoBjuoKzAeQoQE3Y5mzsKcmUaouha5ruV9IbNJJsmq4vGHDTgTMgOgB43nGSgwFkKEBN2ObkrHnJkJmkbIeRzCzceHM6sydqsJrz9EKGIsEZLrRUgTIiRIcIQICbofSUbuPxJkKXpwNVTVbDNVkbFbo8txRjuwKpmj7ul6SIiQILERIiSIC3rSYNSUZEI1buTAyWbbSJJEapKZYFjD5TbWJr1kNgGgBYQICRIbIUKCuKCZMzClJxOurUN2l7TYLs0RnRE4a4zlriw3zITEcpwgwREiJIgLupqGKT0VNI1IVSlEmj+Y2Sclelaoqs5oM6GGPSFjjVtgPIQICeKDrCJnDwEgVFOHHKpptllmalSEag22HNfgmKCHQnG2RCDoWoQICeJH2lBkm5VQTR1SsKLZJhn1MyFvIGyo5HanXLSNJb4C4yFESBA39IZ9oZo6pBYOrSZZVRRZwh+IEA4bJ3SPcNEWGAUhQoK4oalpmNJS0PwBpNpDoDed6ZhMClazgj8UMdRZodhMSHjHCRIcIUKC+KEkoWZkABCqqkYK1zVpoioyVrOKPxAmbCARavCO08Q5IUGCI0RIED8kCSmjACSJsMuDFHY1aWJS5OhMKBghbKDQPZIpek5IuGgLEh0hQoK4otsGoiYnEa7zIAXLm9SrqnRKhDTj7Ak1iJDYExIkOmq8DRAYG92UjpriIFBWieQ/AamN6xVZxmZR8QfD+ALGcVeWZBkUBT1srHBFbcHn8+B21xCJ9Pz3prxcRktgr05FUXE40rDZkjp8DSFCgriimVJRU5LwHzuJ5DoG2RpIjSfoDpsJTYc6r7FmBZJqEiL0DXw+D3V11aSlZWEymZEkKd4mnRFVlRN2GVnXdUKhIDU1ToAOC5FYjhPEF9mOkpoGQLjWhRRpGlE72R5dmqquM85MCEAyqeKw6jdwu2tIS8vCbLb0eAFKdCRJwmy2kJaWhdvd/GHztiBESBBfJAk5Mxo5IVznbtY5ITkp6q7s8hjr4KakquhhIUKnE4mEMZnM8TZDcBomk/mslkaFCAnijp40ACXJTrjWgxSsblKfZq8XIYMtx8mqCT0kluO+iZgB9SzO9nkIERLEHd3UBzUlibDLgxxsmtYhLSV6ZsbjM9YXspgJCYyAECFB3NHVZNQUB5rfD+7SJvXp9ekcfAY7sCqZVOGYIEh4hAgJ4o6uJKMkRz1rIrWVoDXe+7GYFcyqjD8YIRIx0Fkh4R0nMADCRVsQf2QVObUvsJuw24sSrkOvD1sD0dA9ZpNCMBypj6StxM3U7kQymYR3nMHYsuVDFix4sNm6WbNu4sEHf9mo7Ouv9/GjH81BlmXee28rpvpDzmdi3749vPbaq3z99T6qq6txOBwUFg5j7twfM2bMuE4ZR3sQIiToEUhpuUiqQqTOgxquQzdnxuoUWcJiUgiENMKGmgmp0SVKgWEoKjoAwIMP/hKbzd6obvjwkU3av/DCH8nJ6ceJE6UcPnyIwsKhrd7j+PFjRCIRZs6cRWZmJnV1bjZuXM8999zJ4sXPMmnSlM4ZTBsRIiToEeiWHBSHnYjbhxSsBPvgWF10JiQTDEWMtSekij0ho1FcfIC0tHRmzbqp1bbbt3/OV199ye9+93seeOAeSkqK2yRC06ZdwbRpVzQqu/76m7j55utYufJv3S5CYk9I0CPQ1RRUh52w24sccjaqOzUTMl78OOEdZyyKiooYNmx4m9q+8MJzXH/9jUyYMBFFUTh4sLjD97VaraSlpVFX1zSSfVcjREjQI9BVB4ojKRo1uq6xh9zpM6FIgoZAaQ5JVcU5IQPh9/spLT1Gbm4eNTU1jf4f/saM+IMP3uPQoUP88IdzUVWVgQNzKSkpatf9vF4PNTU1HDlyiP/5nz9RUlLMxInnd+aQ2oRYjhP0CHQlCbXeQy7sqoGIDxQbALIsYTWrBEMaAQN9KQvvuLazbdcJtu48EW8zuGhsPy4c069DfUtKitA0jTffXMGbb65oVLdmzXoyM7MACIfDvPji83z3u7eQnp4OQH7+YA4c+Lpd91u06Nd8+OH7AJhMJmbNupE5c+Z2yPazQYiQoGcgKchpOcAuIm4vSsSDXi9CADaLgg7UeY2zPCUOqxqL4uLoTOa///tR0tP7xMplWY4JEMDate9QW1vL9773w1hZfv4gtmz5EJ/Ph8126nNzJubOvZPrrruB8vJyNmxYRzAYJBwOYzZ3b1gkIUKCnkNyfyST2qyHXJI16npqpEja4rBq27lwTMdnID2FoqKvMZstTJt2BYrS/DGEQMDPX/7yEldcMZ2ammpqaqJhrpKTU9B1nYMHixk1ajShUAiXq7ZR37S09EbXLSgopKCgEIArr5zBj340h0WLHuGxx57sohE2jxAhQY9Bt2SjJNmIePxIoWrglIecw1YvQj7jzAwkVZwTMhLFxUXk5eW3KEAAK1b8jYoKJ6tWvcGqVW80qS8piYrQrl07uPfeeY3qVq58h379+jd7XVVVufjiS3nttVcIBPxYLNazG0w7ECIk6DHoagpKko1QZS1y0EnktLoGEXIbKH5cg4u2rusiaKcBKC4uYsqUC1qsd7lcLF/+GjfcMJtzzz2vUZ2m6TzyyEMxD7nCwmE888yfGrXp0yfjjPcPBALouo7X6xUiJDAmupqEkmQjcLwcfI1TfTfkFPL4jTMzkNT6j2ckAqr4qCYyZWUnqatzMXjwkBbb/PWvfwF05s27B7u9aQK5P/1pCSUlURFKSUlh0qTJzV6nuro65tDQgMfj5oMP3iM7u2+j/ajuQPxlC3oMuuJATYpuqmquKtBCIEfFpyGnkNdvoJlQfQgWPRw6JUiChKTBKaElESovL2PVqhXMnv29ZgUIoH//ATEROhMLFy7AbDYzevRYMjIyKS8vY+3ad3A6y3nkkUUdH0QHEX/Zgp6DbEZOjmZZjXi8SBE3uhz9xZZSn1MoENKIaBqKnPhH3BqERw+FoftWRwRxoLg4Gq5n0KDmRejVV19E1zVmz/5+i9cYMGAgX331BS5XLSkpqS22u+KKq3j33bWsWvUGdXUukpOTGTVqDP/1X79psszXHUi6rsftCHowGOTZZ5/l7bffxuVyMWLECO6//36mTp3aat+ysjIWLVrEtm3b0DSNKVOmsGDBAnJzc2NtTpw4wapVq9i8eTOHDx9GlmWGDRvG3Xff3aZ7NEdlpRvNQKf2myMrKxmns2tOVqsn11L9zkrsQ/MwTb0TzToQAGeNj4df+oShA1O576ZxmE2JH8S0ZvOHlC9byuCnnsH0jeWT5ujK59JTOHnyMDk5+fE2o82oqkzYAAesz/RcZFkiI8PRYt+4/pz85S9/yWuvvca1117Lww8/jCzL3HHHHXz55Zdn7OfxeLj11lvZvn078+bN495772XPnj3ceuut1NaeckvctGkTL7/8Mvn5+fzsZz/j7rvvxuPxcPvtt7NmzZquHp6gA+jWbGSbNRpDLuyOlZ8exDRikB8Bp2ZCxtkHExiPuC3H7dy5k7Vr17JgwQJuv/12AGbNmsU111zD4sWLWb58eYt9X3/9dQ4fPszq1asZNWoUABdffDEzZ85k6dKl3HfffQBMnjyZDz74gD59Tm20ff/73+e6667jD3/4A7Nmzeq6AQo6hG7ug5JkJez1IwcrYh5ySkM6h1DEOCJkqhchcVZIkMDEbSb07rvvYjKZmD17dqzMYrFw0003sX37dsrLy1vsu2HDBsaPHx8TIICCggKmTp3K+vXrY2VDhw5tJEAAZrOZSy+9lOPHj+MXYfJ7HkoSapKdiNuLHqw8VSxLmFWZYFgjYpBI2pJanxsmIkRIkLjETYT27t3L4MGDSUpq7OkxduxYdF1n7969zfbTNI39+/czevToJnVjxozh0KFD+Hy+M97b6XRit9uxWCxnbCfofnTFjpJki7olu8ugfstSkSVMJpmQkWZCanTfSzNQvDyB8YjbcpzT6aRv375NyrOyojGSWpoJ1dTUEAwGY+2+2VfXdZxOJ3l5ec32P3z4MBs3buTqq6/u0AHAM22wGYmsrOSuubBmx5uZihuwRvzYMsygWAmGItitZmrdQVLT7GRlNO+mmkiYMlIoBdKSzaS08f3usufSQygvl1HV3uUZ2dvs7QiyLHf4by9uIuT3+5tNRdswOwkEAs32ayhvLsheQ9+Wltl8Ph/33XcfNpuN+++/v0N2C++4rvfCUk1R91JXhQvPyZPo5gw0TUdGxx+MUO6sQ9ESf0nO64k6JFRXuAi04f02gnecpmm9ytvMKN5xmqa1+LfXmndc3ETIarUSasbrp0FkWloqaygPBpsGsmzoa7U2PVQRiUS4//77KS4u5pVXXiE7O7vDtgu6mJR+IMtEPD7UiAedDGRZwmxSCIU1AuFI69dIAKT6GGLCMUGQyMRNhLKysppdcnM6o1k1WxKJtLQ0zGZzrN03+0qS1OxS3a9+9Ss2b97M73//e84/v/sTNwnajm7OREmyoXl8SOFTv66s5uiXssdrjC/lUxETjDFegTGJ22LliBEjOHjwIB6Pp1H5jh07YvXN0XDgdPfu3U3qdu7cSX5+fpN8Gk888QSrV6/moYceYsaMGZ00AkFXoZvSUOxWIl4/cuiUh5zNEv3N5DFIJG1JES7agsQnbiI0ffp0QqEQK1eujJUFg0FWr17NhAkTYk4LpaWlFBc3jod05ZVX8tVXX7Fnz55YWUlJCZ988gnTp09v1Pbll1/m1VdfZd68ecyZM6cLRyToLHQlCcVuI+LzQ7AqVm6vFyG3QYKYxg6rChESJDBxW44bN24c06dPZ/HixTFvtrfeeovS0lIef/zxWLv58+fz2WefsX///ljZLbfcwsqVK7nzzjuZO3cuiqKwdOlSsrKyYgdfATZu3MhTTz3FoEGDGDJkCG+//XYjG77zne9gt9u7fKyCdqLYUOxW0DT0upPQVwdJwm6N/rkaJYjpKREyhugKjElcA5g++eSTLFmyhLfffpva2lqGDx/Oiy++yHnnnTmInsPhYNmyZSxatIjnn38eTdOYPHkyDz/8cKMQ5fv27QPg0KFD/OIXv2hynU2bNgkR6oFEZ0JR55KIxw1aABQrdkt0j8QbMIoINTgmGMMRQ2BM4ipCFouF+fPnM3/+/BbbLFu2rNnynJwc/vCHP5zx+j/96U/56U9/elY2CuKApCAnRxNwad4AcsSDrlhJthttJnQqlYPAGGzZ8iELFjzYbN2sWTfx4IO/bFT29df7+NGP5iDLMu+9t7XZYy/fZO/ef7Nu3T/48st/cfLkCVJSUhkzZix33HE3Awfmttq/sxGpHAQ9k+QckCQiXj9KxItOBg5b9GyY3zAzoYblODETMgpFRdGUDg8++EtstsarNMOHj2zS/oUX/khOTj9OnCjl8OFDFBYObfUey5e/xq5dO7jsssspKBhKZWUFq1evZO7cH/DSS68xaNDgzhlMGxEiJOiR6JZMZJsVzetDikQ9KB312VUD4Uj08Kqc2CmvYyIkYscZhuLiA6SlpTNr1k2ttt2+/XO++upLfve73/PAA/dQUlLcJhH67nd/wMKFv200a5o27Qpuu+17LF/+Gg8//MjZDKHdCBES9EzUNBS7hYgvgBSKeshZTAqKLBEKRxPbyXKC5xSSZZAksRxnIIqKihg2bHib2r7wwnNcf/2NTJgwEUVROHiw9ayqAGPGjGtSlpubx6BBQzh06GC77O0MEj+okaBXoqv1btpeH1KoBqiPpG2SCRokp5AkSUiqKpbjDILf76e09Bi5uXnU1NQ0+n/4G276H3zwHocOHeKHP5yLqqoMHJhLSUlRh++t6zrV1VWkpaWd7TDaTafMhMLhMJs2baK2tpbLLrus2YgFAkF70OvdtPVQGLxlQEM6B4VQ2EiRtFUxEzIIJSVFaJrGm2+u4M03VzSqW7NmPZmZ0e/VcDjMiy8+z3e/e0vMGzg/fzAHDnzd4Xv/85/rcTrLufPOuzs+gA7SbhF68skn+fTTT3nzzTeBqILOnTuXf/3rX+i6TlpaGitWrGgxirVA0BYaDqwCaHW1oIWQZQlTQ04hQ4mQmAm1RujrbYT2fxRvMzANvwTTsAs71Le4ODqT+e//fpT09FN50GRZjgkQwNq171BbW8v3vvfDWFl+/iC2bPkQn8/XJGJMaxw+fIinn36CsWPHc+WV3R9Rpt0itGXLFi644ILY6/fff5/PP/+cH//4x4wcOZJHH32UF198kccee6xTDRUYDNmMnBQNDR+pd05QZAdmVY6m+I4YSYTETMgIFBV9jdlsYdq0K1CU5vc7AwE/f/nLS1xxxXRqaqqpqakGIDk5BV3XOXiwmFGjRhMKhXC5ahv1TUtLb3LdysoKfv7z+0hOTuHRR3+HLHf/Dk27RejkyZPk5+fHXn/wwQcMHDiQBx+M+rYfOHCAv//9751nocCwSCk5AER8AUwRH4qcjMmk4PaFDJNOQ1JUEbanDZiGXdjhGUhPobi4iLy8/BYFCGDFir9RUeFk1ao3WLXqjSb1JSVREdq1awf33juvUd3Kle/Qr1//2Gu3282DD96Lx+Pmz39+hYyMzM4bTDtotwiFQiFU9VS3Tz/9tNHMKDc3t9kI1wJBe5FsWUgWM2G/FqoAACAASURBVJrXB5oXxXRaim8D5BOChpmQECEjUFxcxJQpF7RY73K5WL78NW64YTbnnts4qoym6TzyyEMxD7nCwmE888yfGrXp0ycj9t+BQID58+/n6NEjLFnyZ/LyBnXeQNpJu0UoJyeHL7/8kptvvpkDBw5w9OhR7r333lh9ZWWlCIUj6BQ0UzqK3UrYG8AarEa2DTklQgZZjkOIkCEoKztJXZ2LwYOHtNjmr3/9C6Azb9492O1NMwv/6U9LKCmJilBKSgqTJk1u9jqRSISFCxewe/dOfve73zN69JhOGUNHabcIXX311Tz//PNUVVVx4MABHA4Hl156aax+7969wilB0CnoqgPFbiVU6UIOVyNLEhazgqbpeA0USVs4JiQ+DU4JLYlQeXkZq1atYPbs7zUrQAD9+w+IidCZ+OMfl7B160dceOHFuFwuNmxYF6uz2exccsm32j+As6DdInTXXXdx4sQJNm3ahMPh4IknniAlJQWAuro63n///UaRrAWCjqIrSSg2GwF/OfijB1YbEtu5DRM/TjgmGIHi4mi4nkGDmhehV199EV3XmD37+y1eY8CAgXz11Re4XLWkpKS22O7AgWhGgm3btrBt25ZGdTk5/bpdhCRd1zttXUPTNDweD1artU2B9HojlZVuw2yKt0RWVnKL+eQ7lYgHPv8DdTv3k37xRMIj7uavGw/w/hfH+fHVI7lgTL+utyHOHF38BEQi5M5/qNW23fZc4sjJk4fJyclvvWEPQVVlwuHE378803ORZYmMDEeLfTs1bE84HCY5ObkzLykwMrItdlYo4vWC5osltvMYaCYU8fvjbYZA0GW02yl88+bNPPfcc43Kli9fzoQJExg/fjz/+Z//SSgklg8EnYAkI6dEPXoivgBSxBdLbOcx0J4QIoCpIIFptwi98sorlJSUxF4XFxezaNEisrOzueCCC1i3bh3Lly/vVCMFxkW3ZyMpChGPDyniJckaXeb1GSidgx4yxlgFxqTdIlRSUsLo0aNjr9etW4fFYmHVqlW8/PLLzJgxgzVr1nSqkQLjopv7ICfZ0Lx+pIgnls7BFzTGF7OkqCKVgyChabcI1dbWNkqh/fHHHzNlyhQcjujG0/nnn8+xY8c6z0KBsTGlo9gsRLwBpFD1KREKGMNtWTIJF21BYtNuEUpPT6e0tBSIhn3YtWsXEydOjNWHw2EiEfGhEXQOumKPpnTw+SBQSZJFRQKCoQha5zl29liiYXuMsf8lMCbt9o4bP348f/vb3ygsLOSjjz4iEolwySWXxOoPHz5MdnZ2pxopMC4NKR3QNPCUoWYo0Uja9UFMZTXBs6uaRMQEQWLT7pnQvffei6Zp/OxnP2P16tXMmjWLwsJCIJrW4b333mPChAmdbqjAmERnQlYgmtJB0cOYTDKhsGaI81oigKkg0Wn3TKiwsJB169bxxRdfkJyczKRJk2J1LpeL2267jcmTm49ZJBC0G9mCnBTdb4x4/ZgkP2ZVIWiQxHYigKkg0enQYdW0tDS+/e1vNylPTU3ltttuO2ujBILTkZL7giQR8fpR8BkqkrakqqDr6JEI0hlC/AsEvZUOR0w4cuQImzZt4ujRo0A0hcO0adNE8FJB52NOR7bZ0Lw+TLoPk0nB4w0aYzmuPm2KHg4LERIkJB0SoSVLlvDSSy818YJ76qmnuOuuu7jvvvs6xTiBAEAz9UGxR920zZoLiypTbZAU36eLEBZLnK0RCDqfdovQqlWreOGFFzj33HP58Y9/zNChQ4FoRtVXXnmFF154gdzcXG644YZON1ZgTHQ1GcVuJVDjRAnVYFYz65fjDCZCAsNw5Mhh3nhjOZ9//ilOZzmqqpKbm8eUKRcya9aNZGf3BWDLlg9ZsODBWD9FUUhJSWXo0OFcddXVfOc709t0v3379vDaa6/y9df7qK6uxuFwUFg4jLlzf8yYMeO6ZIwNtFuEXn/9dcaNG8eyZcsaZVjNy8vj0ksv5Qc/+AF//etfhQgJOg1dSUKx29DDYRR/BSY1i1BYI2SA6MQxERJREwzD+vX/4KmnHsfhcHD55VeQnz+YcDjMvn17WLHidTZufJeVK98BoKgomgLi/vt/jsORTDgcxuksZ8uWzfz6179i69bNLFz4W2T5zI7Qx48fIxKJMHPmLDIzM6mrc7Nx43ruuedOFi9+lkmTpnTZeNstQsXFxTzwwAONBCh2MVVlxowZPP30051inEAAQMNZIYC6MiymaNgojy/xD3HGREjEjzMEmzd/wOOP/4bJk6eycOFvY5FoGrjrrntYv/7vsdfFxQew25O44YabkaRTZ+Zuu+1HPP30k7z11komT76AGTNmnvG+06ZdwbRpVzQqu/76m7j55utYufJvXSpC7T4nZDKZ8Hq9LdZ7PJ6EzSUkiA+nnxWK+HzYLdEZkMsbjKdZ3YKkRj9LYiaU+NTV1fHUU79l8OACHnvsiSYCBJCZmcmcOXNjr4uKihgypKCRAAFIksS8eT9BVVU2bny3Q/ZYrVbS0tKoq+vaHFXtFqExY8bwxhtvUFFR0aSusrKSFStWMG5c164hCgyGpCAn16d08PhJMkdFyAjpHCQ16hEn9oQSn7/97a/U1NRwzz0/w2Kxttre7/dTWnqMIUMKmq1PSnIwcGAuR48eabMNXq+Hmpoajhw5xP/8z58oKSlm4sTz29y/I7R7Oe7uu+/m9ttvZ8aMGdx4442xaAlFRUWsXr0aj8fD4sWLO91QgbHRrRnIVgsRrw9HctQr0+0zwBezIhwTjML772+kX7/+Tb703W434dOev81mxWKxUlJShKZpFBQUtnhNWZbR2nGebtGiX/Phh+8D0VWvWbNubDTz6graLUKTJk3iueee49FHH+Uvf/lLo7r+/fvzxBNPNApoKhB0BropHdkeTemQnBEAwGuAmZBcv7QtROjMfHpiO/934vN4m8HUfpOY3O+8dverqqrk6NEjzJgxs8nS2pw5N+N0lsdeP/TQQmbMmElxcREAQ4a0LEK1tTUxT7q2MHfunVx33Q2Ul5ezYcM6gsEg4XAYs9nczhG1nQ6dE/r2t7/Nt771LXbv3h1L25Cbm8s555zDihUrmDFjBuvWretUQwXGRlf7oNgshCpqSDPVAWZ8RkjxrYjlOCPgdDoB6Nevf5O6hx9+BF3X2bp1M2++uYKCguixmKKirwFanAlVVFRQWVnJZZddDkAoFMLlqm3UJi0tHeW0Q9AFBYWx61155Qx+9KM5LFr0CI899uRZjrBlOhwxQZZlxo4dy9ixYxuVV1dXc/DgwbM2TCA4HV21oyRZCRwPkKZUA33xGiCxXcwxQYjQGZnc77wOzUB6CqFQdFbfXBqchuW5rVs3oygKgwcPAaC4uIjMzCxSUlKbveamTRsAuOiiSwHYtWsH9947r1GblSvfaVb4IOrtfPHFl/Laa68QCPjbtE/VETosQgJBd6IrNhRb9EOQHCoH+uIPJn7eKuGYYAz6948KwcGDxS22KS4uIi8vP7Y0VlxcxMiR5zTbtqqqkmXLljJs2IiYiBUWDuOZZ/7UqF2fPhlntCsQCKDrOl6vV4iQwNg0HFgFUANuTKpEIBhNbCdLiZtTqGEmhBChhKZPnwzGjh3P1q0fsWfPbkaNGt2oPhgMUlJSzPnnR8/rlJWdpK7O1exS3LFjR3nooQfxer089NDCWHlKSgqTJjWf4aC6urpRxmwAj8fNBx+8R3Z2X9LT+5ztEFtEiJCgdyBbkJOSAZACASyqRDAUzSkkK4ksQsI7zig88MB87rnnDn7ykzu46qprKCwcRiQS4ciRw3zwwUbc7rrYrKbBKcHlqmXDhnVomkZtbQ27du1g27YtpKam8eyzz1NYOLRN9164cAFms5nRo8eSkZFJeXkZa9e+g9NZziOPLOqyMYMQIUEvQrdnRr+U/QEsKtH4cREdNYGDS4vlOONQWDiUl19extKlL7Nt2xbWrn0Hm81OXl4+M2dez1VXXUNeXj4QjZQAsHbtO6xd+w5ms4XU1FQKC4fy058+wNVXX4vV2vblsyuuuIp3313LqlVvUFfnIjk5mVGjxvBf//Ubzj23a/fa2iRC33TFPhNffPFFh40RCM6EZM5ATrKh+/xYVL0+sZ0GJK4KnXJMSHx3dAEMHJjLr37161bbzZkzt1PP71xzzXVcc811nXa99tAmEXriiSfaddFv+rkLBJ2BZkpHtVkI1nqwqiGq/SbCCR5J+9RMKPGdMATGpE0i9L//+79dbYdA0Cq6moJst6KXVZKk+CkLW4lEEl2ExExIkNi0SYTOP79rYwcJBG0hGsjUBrpOplLNvnBKwmdXPZXKQcyEBIlJuwOYCgTxQlfsyPZodtFMqZZQWCOY4MtUkiyDLAvHBEHCIkRI0HuQraiOqJt2uuQGjBJJWxXLcYKERYiQoPcgSeDIQVJV0vSoCLk8if/lLCmKcEwQJCxChAS9C3MGisOOQ48mVnT7jJHYTsyEBImKECFBr0IzZ6AkWbGHG0Qo8b+co8txYiYkSEyECAl6FbqajJpkxxQJYiGE22sUEUr8cQqMiRAhQa9CV+woSdFAptlKLR7DzISEd5wgMYmrCAWDQZ566ikuuugixo4dy80338z//d//talvWVkZ9913HxMnTmTChAncfffdHD16tEm7P//5z/zHf/wHF154IcOHD+e5557r7GEIuhFdcaA47AD0VVx4/f44W9T1SKoqzgkJEpa4itAvf/lLXnvtNa699loefvhhZFnmjjvu4MsvvzxjP4/Hw6233sr27duZN28e9957L3v27OHWW2+ltrZx5sAlS5awc+dORo4c2ZVDEXQXshk5OR1dkuinVsfynSQykqqihxJ/xicwJnGLor1z507Wrl3LggULuP322wGYNWsW11xzDYsXL2b58uUt9n399dc5fPgwq1evZtSoUQBcfPHFzJw5k6VLl3LffffF2m7atImBAwficrmYNGlSl45J0D3oliwkm41+oVr2B4NENB01wdM5iJmQsThy5DBvvLGczz//FKezHFVVyc3NY8qUC5k160ays/sCsGXLhyxY8GCsn6IopKSkMnTocK666mq+853pbbrf3r3/Zt26f/Dll//i5MkTpKSkMmbMWO64424GDsztkjE2EDcRevfddzGZTMyePTtWZrFYuOmmm3jmmWcoLy8nOzu72b4bNmxg/PjxMQECKCgoYOrUqaxfv76RCA0cOLDrBiGIC5opA9luJdvtIhgMGSCdg4oWTHxXdEGU9ev/wVNPPY7D4eDyy68gP38w4XCYffv2sGLF62zc+C4rV74DQFFRNKXD/ff/HIcjmXA4jNNZzpYtm/n1r3/F1q2bWbjwt8jymRe9li9/jV27dnDZZZdTUDCUysoKVq9eydy5P+Cll15j0KDBXTbeuInQ3r17GTx4MElJSY3Kx44di67r7N27t1kR0jSN/fv3893vfrdJ3ZgxY9i2bRs+nw+bzdZltgvii27OQLFbSZdOEgyFCGsalgRO54Ciokd88bZC0A1s3vwBjz/+GyZPnsrChb/F4XA0qr/rrntYv/7vsdfFxQew25O44YabG2UvuO22H/H000/y1lsrmTz5AmbMmHnG+373uz9g4cLfYjKZYmXTpl3Bbbd9j+XLX+Phhx/pnAE2Q9z2hJxOZ7Mik5WVBUB5eXmz/WpqaggG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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "data1 = [\n",
    "        #  dict(name = r'$GD$-1',x=np.array(range(niter+1)),obj=l_obj_A,trace = l_trace_A, reconst = l_reconstruct_A),\n",
    "         dict(name = r'$GD$-2',x=np.array(range(niter+1)),obj=l_obj_MGD2,trace = l_trace_MGD2, reconst = l_reconstruct_MGD2), \n",
    "        dict(name = r'$GD$-3',x=np.array(range(niter+1)),obj=l_obj_MGD3,trace = l_trace_MGD3, reconst = l_reconstruct_MGD3), \n",
    "         dict(name = r'$FA$-2',x= np.array(range(niter+1)),obj= mean_obj2,trace = mean_trace2, reconst = mean_rec2),\n",
    "         dict(name = r'$FA$-3',x= np.array(range(niter+1)),obj= mean_obj3,trace = mean_trace3, reconst = mean_rec3)]\n",
    "\n",
    "\n",
    "for plots in reversed(data1): \n",
    "  plt.semilogx(plots[\"x\"], plots[\"obj\"])\n",
    "  if plots[\"name\"] == '$FA$-2':\n",
    "    plt.fill_between(np.array(range(niter+1)), mean_obj2 - 2*std_obj2, mean_obj2 + 2*std_obj2,alpha = 0.3,color='orange')\n",
    "  if plots[\"name\"] == '$FA$-3':\n",
    "    plt.fill_between(np.array(range(niter+1)), mean_obj3 - 2*std_obj3, mean_obj3 + 2*std_obj3,alpha = 0.3,color='b')\n",
    "  plt.legend([plots[\"name\"] for plots in reversed(data1)])\n",
    "\n",
    "\n",
    "plt.ylabel(r'Loss')\n",
    "plt.xlabel(r'Number of iterations')\n",
    "\n",
    "plt.savefig('obj_values', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 504
    },
    "id": "nMQEjkiUHsjW",
    "outputId": "b18ad501-3718-404d-8d20-17ec8a95b6c7"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "$FA$-3\n",
      "4.999999962669929\n",
      "3.3365294419159954e-05\n",
      "$FA$-2\n",
      "5.000000363404998\n",
      "6.061644237035597e-05\n",
      "$GD$-3\n",
      "4.0172356692610364e-14\n",
      "4.999999999999924\n",
      "$GD$-2\n",
      "5.000000000016071\n",
      "3.7153924624731556e-06\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYcAAAEbCAYAAAAxukhGAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOy9eXwV5b34/57lrDnZyZ4AIUDCvqMiCihKq9bauvSWqlVp1Uq1ttVa6b1Fa9VvW63W+/PaXm0ttVTt9YrbVVaVKoiyKPsOgez72bfZfn8cCBwTkpMFEsK8X6+84Mw888xnzjKfeT6rYBiGgYmJiYmJyUmIfS2AiYmJiUn/w1QOJiYmJiZtMJWDiYmJiUkbTOVgYmJiYtIGUzmYmJiYmLTBVA4mJiYmJm0wlYOJiYmJSRvkvhagt2hpCaDr53bKRmami6Ymf1+LYfIlzM+l/2F+JiCKAunpSafcP2CUg64b57xyAMz3oJ9ifi79D/Mz6RjTrGRiYmJi0gZTOZiYmJiYtMFUDiYmJiYmbegzn8Onn37KzTff3O6+d999l5KSkjMskYmJiYnJcfrcIf3d736XMWPGxG3LycnpI2lMTExMTKAfKIfp06czd+7c034eTdOIRsPouoZh6Kf9fH2BpgUJhaJ9LcZpRxBErFY7Fou1r0UxMRmw9LlyAPD7/djtdmT59IijKFEikTA2mw1JciAIAoIgnJZz9SUulw1JivS1GKcVwzDQdY1wOAhgKohzAUNH0PygRwmFI1Q2hvGGDCw2FxlpLtJdNhw2eUD+pvuSPlcO999/P8FgEFmWOe+883jggQcoLS3t1XNEoxEcDieS1OeXa9JDBEFAkmTsdifhcNBUDgMYIdqA7N+NFDwEhkY4qlFf58MmCuRLIprfQGmQqCQZw5qOK3UQSa4MJNmGrktEwxGiUT2Wz2CAoRtg6Oi6TnOyHa8v3HouQ1XB68WIRhFO7n/Wbi+0/pMfIUgyhRfNQbZaen3uPrtbWiwW5s2bx8UXX0x6ejp79+7lL3/5C/Pnz+e1116juLi4185lGBqiKPXafCZ9jyhKA9Y8eM6jhbC4NyAF9mNITnTrIDRD4FCdB6wurBYJFUDTsPmbcPmOEvXuIhqIEtLC2FGQBR07YO/gNJnE7v2+CgjU0Z/u+V1i7+6tjPnh/b0+r9Cf2oTu2bOHa6+9lq985Ss8+eSTvTZvbW0dqanpvTafSf/A42khN9cMXhhQRFug6v9AC4EtB46ZiuqaA1TU+UlxWhBaGhBqjiI01iLoGgBNWhKNejJRyY5ks2B3JWNxpWJzJCFZbIiyBSQroiSDKCGIsSh+Zcs2oh99glw2AmlIEYLVCuKXIvz7sblKECXGXH89Nqez1+fuV3aWsrIyLrjgAjZs2NDlY5ua/KdMhw+FogPeFg8xn4PfP/Cv8zihUJSGBl9fi9EpWVnJZ4WcfY2gtGCrextDtGJYUiEaM/tous7BihaSQm6EHfuQgl502UIgvYC3a4eyI5DLhMIQIwanM3LEaLKzcxA7uaFnZSVTX+fh0F9fxTlqDAU/ue+s9Vl4AxoEuv79EkWBzEzXKff3K+UAkJeX1y3lYGJichajBbE2LD+hGE7C7wuSUr4Dp7sWzeYgWDyWQGo+L3yWRnPIyjXTk7C4xjKuNIf0ZFvCp4wcKUfzuEm54VtnrWI4nfS7DOmKigrS000TUH+ipqaaOXMuYM+eXV0+dsuWTcycOZUtWza1bnv44X/nl798sDdFNDmbMXQszR+CrrRRDJrPS2T9hzjcdYTzS/CPvwglK4+Ve2Vq/TauPG8wlpQiRg5O75JiAAju2Q2As2x0L13IwKLPVg7Nzc1kZGTEbdu0aROffvop11xzTR9JdXbx7rtv89hjD7e77447fshNN93S+vrJJ3/DsmX/w5VXXs2DD/6yS+d58cXnGT9+EmUn/YhWrnyPd955k/Lyw/h8XjIzBzF58lRuu+12cnPzOpxv/vybWbDgRg4ePEBJyfAuyWIy8JB8O5FCleiOorjtaksznnUfggGBsmloqZkIhkpNk4/PqkYyecQgBmWkIEkCBYNObR45FZHKCuSMDOTU1M4Hn4P0mXK49957cTgcTJo0ifT0dPbv38+rr75Keno6d999d1+JdVZy++13kZOTi90uEw6rAIwYcSIcWFVVPvhgFXl5+axd+wE//enPsVoTCwFtbm5ixYp3Wbz40bjtBw7sIysri/PPv5CUlBTq6mp5663XWb/+Y5YseZnMzEGnnHPEiJGUlY3m1VeXsmjR4m5csclAQVCakT2fodviHyiU5iZ869aCxULDkIk4UlPBULGqdbxxYBJJdonzRufiDUaYNCILUey6WShaU4M1L7+3LmXA0WfKYe7cubz99tu8+OKL+P1+MjIyuOqqq7j77rvJzzc/sK5wwQUXMmJE6Skd0hs3bsDtdvPII7/hnnvu5JNP1jFr1pyE5l6x4j2sViszZsyM237XXT9qM3bmzFksWHAjK1a8x/z5N3U475w5c3nxxef5yU8ewG7vKODQZMBi6FhaPgHJAeKJW5Hm9+H75F8INhv+0qmIhgUMHbtax2bvZKpbdC6dnItuGLgcVtK6aE6KnVonWltD6sjezakaSPSZcrj55ptPWXjPpHdZuXI5ZWWjmTRpCuPGTWDVqvcSVg7r1v2LMWPGJXQDz83NBcDv7zxyYtq083j22afZtOkzZs68OCFZTAYWYrAcMVwVZ07SoxG8n3wEgOv8i6hsVHBaJWxaLX5rKZ+UO0myhykbkoY3EKVsSHqnkUntEW1xY0SjWHNye+16Bhr9ziFt0nV8Ph9ut5uWlhbcbjcej7t1XygU4uOP13LJJZcBcOmll7N+/ToCgc5bJKqqyu7dOxk5suyUY7xeDy0tzezZs6vV/zF16vRO5x46tBibzcb27Vs7HWsyANGjWNzr0a1ZrZsMw8C/6VP0YIDk82YStTowDAOr4SYqZXIoOoaj9X7Gl2TGFIIAg1K7t+pUWloAkNPSeuVyBiL9LpTVpOvcc8+dca8dDgerVsWevj76aC3hcLhVOcyZcynPPPMkH374PldeeXWH89bV1RKJRDo0833729/E4/EAkJqayo9//DMmT57aqcyyLJOdnUN5+aFOx5oMPCT/XtDDYM1s3RY+sBelroakCZOxDMqipSWIZCiIhkqzYyY7d3gRBYGxxZkEIyqDUh1Y5O5VPoi6Yw9QkumMPiXntHJYt72Gj7fV9LUYzByfx4XjOo7w6Yj77nuQgoJCHA4LoZCCJJ34waxevZwxY8a1mnwyMjKZOHEKq1Yt71Q5HF+BJCennHLMo4/+jlAoxNGj5axY8R7BYDBhuZOTU1oVi8k5hBbC4t2Mbs1u3aQ0NxHcuQ1rfiG24lgEm9cfIVlsptk+G1Vwsb+ykiG5Lhw2mWZ/mLyM7mcFR5uPrRxSzZXDqTinlcNAYcyYse06pD0eN599toFvfes7VFZWtG6fMGEif/3rCzQ1NXYYVXScjiqsTJw4GYg5xS+6aDY33/wtnE4H1177rYTmNXOPzj0k/y4wdBBjxeIMTcO/+VNEu4OkSdMQBAFV09Ej9UScwwhZhlDTFMQfUpgxNjf2vTEg1dX9oovHzUpSyqkffM51zmnlcOG4nj2x93fef381qqqydOkSli5d0mb/mjUrueGG+ac8PvXYU5XPl1hqfn5+AaWlo1i5cnlCysHn8zF06NCE5jYZIGgBLL5t6LYTvobQ/j3ofh/JMy5GPBZiHQkHwQCPfSoIAvsr3UiiwLC8FCKKRprL1m2TEsQc0mJSEqKl96uZDhTOaeUw0Fm58j1GjizlpptubbPv1Vf/wcqVyztUDjk5udhsNmpqqhI+ZyQSIRwOdTpOVVXq6+sSjpoyGRhI/t2xUqhC7Naj+X2E9u7CWlCENefEg1rUX02DZSoW0YluGOyv8jA0NxmrRcLtD1OU0/Wkt5OJtrSYJqVOMJXDAKW2toYdO7Zx550/ZM6ctp32mpubeeqp31JRcZSiosHtziHLMmVlo9lzrMzAybS0tLQpc7Jnz27279/L3LmXdypfeflhotEI48aNT/CKTM56tCAW7/bWVYNhGAS+2IwgSiSNn9Q6TIg20xTNQnfE+shXNQQIhlVGFKUdOw5Sk7qe23AySovbzIzuBDOUdYCyatVyDMNgxoyL2t1/4YWx7StXvtfhPDNnzmLnzu2EQvGrgeuuu4pHH32Il1/+O2+88b88/fTvuPvu23E6k/jud7/XqXwbN36Kw+FkypTOw15NBgaSfy9wYtUQrTyK0lCHc8w4RLsjNshQ0ZQgFcYErNbYuP2VbmRJoDg3BU3XkSUBp71nz7XRlhYzUqkTTOUwQFm1ajn5+QUUFw9rd39ubh4lJcNZtWpFh/PMm/dVVFVl/fqP4rZ/85s3cODAPpYseYGnn/4dH320ljlz5vLnP7/E4MFDOpXvgw9WM3v2JTgcjsQvyuTsRQtj8W1tzWvQo1EC2z9HSs/AVlzSOkyI1OOxjSMqpCIIArpucKDKQ3FeChZZJBzRyEx1dCvx7TiGYaC4zZVDZ5hmpbOYK674Gldc8bV29/3tb692evySJa90OiYjI5N5867grbeWcemlJ8xFCxe2LZ/RHpMnT+XjjzfFbdu/fx979uziZz/7RUJzmJz9SIH9GIbWWiYjuHMbRiSKa8YsBOHYM6oWBMlJozEcQYhF3VU0+AlHNUYWxkxKUVXrduLbcfRQED0aNX0OnWCuHEw65dZbv8+2bV90q2R3e/zjH39j9uxLGT58RK/MZ9LP0aNYvFswrLGwaaWpkUj5QewlI5DTjvmtDAMx2oSSfiENXg2H7YRJySKLDMlNbp3O5ehZ33DVHcutMc1KHWOuHEw6JS8vnw8++KTX5lu8+Ne9NpdJ/0cKHsQwFBCtGLpO4ItNiA4HzlFjW8cISiOao5iIXIAvVENaki3WAa7KS0l+CrIkomo6FlnEYetZP3jNG1MO5sqhY8yVg4mJyelDV5A9m1tXDeED+9C8HpzjJyMczzHQFQRDRU0/D39YjfmsBYGjdX4iisaIYyalcFQjM9Xe465t6rHMf9Pn0DGmcjAxMTltSMHDCHoYRBtaMEBwzw4suflY8wpax4jRepSU6RhyCi2+MJIYuy3tq3Rjs0gMPpbToKgxZ3RPUc26SglhKgcTE5PTg64gezeiWzJjOQ1btwCQNGFy69O/oHoxLOlorljl3/qWEA6bjKLqHKr2UlKQ0qosAFz2nmc0a14PotWK6Oh+baZzAVM5mJiYnBak4GEELQSSnWh1FUptNc5RY5GcSbEBhoageIlmXAyiTCiiEoyoWGSR8loviqpTWhRzWPeWvwFiDmlLelqPzVMDHVM5mJiY9D66Emv/acnEUBSC27YgpaRiLxnZOkSI1KGkTsI4lvvg8UdaCzHuq3CTZJcpyIopknBUY1Cqo1du6KrHjTUtvfOB5zimcjAxMel1Wvs1SHaCu7ejh0MkTZqKcMxEJKhekNPQkie0HlPbHMRmkYkoGuW1PkYUprUmuymqRkYP8xuOo3k8WDPMSKXOMJWDiYlJ76IFsXg3YVizUN3NhA8ewFZcgiXjWHl4XUVQfUQzZ7eW7Y4qGi2+CA6rxL4KN5puUFp08g1cINnROxVUVY8bS7q5cugMUzmYmJj0KrJ3KxgGhiDj/3wTgs2Gc/SxAouGgRitQUm7AOOkLnAtvhN9SLYfaiIrzU52eiwySVF1HDapNTGuJ+hKFD0YxGoqh04xlYOJiUmvIUQbkX3b0W3ZRA4fQnO3kDRuYmufBjFah2YvRnONijuuqjGA3SpT1xKi0RNmXHFmq38hFFFbFUVPUZuaAbANyuxkpImpHEw6paammjlzLuhW+YwtWzYxc+ZUtmw5UV/p4Yf/nV/+8sHeFNGkP2BoWJrXYcjJ6JEowV3bkLOysRbGSsILqhdDdKBkXATCiVtPMKzg9kewWyU+39+ARRYZeZJJSdN10pN7x9+gNNYDYD/WNtfk1JjlM85i3n33bR577OF2991xxw+56aZbWl8/+eRvWLbsf7jyyqt58MFfduk8L774POPHT6KsbHTrtrVr32fNmlXs3r2T5uYmcnJyufDCi/nudxfgcnXciGX+/JtZsOBGDh48QEnJ8C7JYtJ/kXy7EJV6dHshwa2fYqgarglTYisALQxqgGjO10GKv9HXNAUQRYEWX4T9lR6mlmZhtcRCVnXdQBAFkp29429QGhoAsOXkENF7ZcoBi6kcBgC3334XOTm52O0y4bAKwIgRpa37VVXlgw9WkZeXz9q1H/DTn/4cqzWx4mXNzU2sWPEuixc/Grf9t799lEGDspg37wpycnI5ePAAr732Chs2rOOFF17CZjt1M5YRI0ZSVjaaV19dyqJFi7txxSb9DSHahMWzAd2ai9JYT6SiHGHoSMKyA6euIEXriQ6aF+dnAIhENY7W+0lx2li58SiyJDBxxIkWosGISlaqA1nqHSOH0tCAYLFgTU+DpkCvzDlQMZXDAOCCCy5kxIhSXC4bfn+kzf6NGzfgdrt55JHfcM89d/LJJ+sSbs+5YsV7WK1WZsyYGbf9kUd+w+TJU+O2lZaW8eijD7FmzcpTlhI/zpw5c3nxxef5yU8ewG7vHZOBSR+hR7E2vY8hp2Ag4t2yCdVip96Vj1HlZpC1kfShs5CcQ9scWl7nRUCgujHA/koP00dl4zzJ8RxVNHIzei+TOVJViSUntzWk1uTU9Kt36Pnnn6e0tJSvf/3rfS3KgGLlyuWUlY1m0qQpjBs3gVWrOu7+djLr1v2LMWPGtbmBf1kxAK0Kp7z8cKfzTpt2HsFggE2bPktYFpP+iez5LOZPkFPw7tkNAR/hoaNISnKQaW2hXhvC+oqcuIgkgEZPiMr6AA6rxPtbKklxWplamt26X9V0ZFkk1dWzEt3HMQyDyNEj2IcM7ZX5Bjr9Rjk0NDTw3HPP4XSa9U66is/nw+1209LSgtvtxnOs6iRAKBTi44/XcskllwFw6aWXs379OgIBf6fzqqrK7t07GTmyLCE5mpqaAEhL6zzBaOjQYmw2G9u3b01obpP+iRg4hOzbhW7LRQ34UfbvJpKahZaRi6y5UcR0lLQLsFotbN7XwO7yZpq9YSob/Gw72ESSQ2b1liq8wSiXTSuKMx/5QwqFWa7eMynV16P5fNiHDu2V+QY6/cas9OSTTzJ27FgMw8Dr9fa1OGcV99xzZ9xrh8PBqlWxtp4ffbSWcDjcqhzmzLmUZ555kg8/fJ8rr7y6w3nr6mqJRCLk5+cnJMfSpUuQJIlZsy7pdKwsy2Rn51BefiihuU36H4LiwdqyFt2WDYKIb+vnsafz4jGIRgTJUGhMugxDsGKzgFUWafSEqWsOYggCLoeFj7bWcLDKw8xxeRQMSmqdW9cNDCAvs/ceFgNbvwDAOWZcr805kOkXymHbtm289dZb/O///i+PPfbYGTuvsm8dyt5/nbHznQpL6cVYRl7Y7ePvu+9BCgoKcTgshEIKknSiONnq1csZM2YcucdC9zIyMpk4cQqrVi3vVDkcX4EkJ6d0KsPKlct55503uemmWykoKExI7uTkFDweT0JjTfoZhoal+V8YghVEG9G6WvS6agJ5wzGsNmxaDY2OOajiie+OIAgkO2MmonBU5b0NRzlS52NaWTaTR2bFTe8JRhmS4+qVxDeIJb+5P3wf29BirNnZnR9g0vfKwTAMHnnkEa655hpGjRrV+QEmbRgzZmy7DmmPx81nn23gW9/6DpWVFa3bJ0yYyF//+gJNTY1kZg7qdH7DMDrcv3Xr5/y///cIM2bM5Hvfu7PDsV+e1yyMeXYi+XYiRmvR7YUYhk5g+xeoVgd6wTBsWiMBy3DClqJ2j21wh/i/DUfwBxXmTCpgbHFG3H5fMEqSXWZwTnK7xwPoioIRjWKoKoamYqgahqrEXqsaaOqx/6vokTCetR+i1NdRcO9PevV9GMj0uXJ44403OHDgAM8+++wZP7dl5IU9emLv77z//mpUVWXp0iUsXbqkzf41a1Zyww3zT3l86rE2ij6f75Rj9u/fxwMP/ISSkuE8/PDjcauWzvD5fAw17b9nHbGw1U/RbbHVaORIObrPg2fwWKyiiqFLeGyT2z1295EWPvi8EptF4tpZw8jLjJmSNF0nquiEogouh5VxwzLb+BqU5iYaXv4HgV07MSLhLsksOhzk3HwrSWPHd+OKz036VDn4/X6efPJJbr/9drJ7uNTLzDx14pWmBXG5Th13f7ZiO7bkdjisrdd38nWuWbOCsrJRLFjwvTbHvvTS31i9egW33XbrKecfNmwwdrudxsa6dt+/iooK7r//HjIzM/mv/3qO9PS2jmjHsWbwJ8sIMWd3Q0Mdl102t9ufjaZZyco69dNlf+JskbNTdA0qV0LaILAmoysK7j07MFLSsRUOJlmox5t8Mcn2+NpFhmHwweZK1m2rZkhuMt+cMwJdN4iqGgBWq0xGuo38QUnkDkpqoxh0VeWLh58i0tBIziWzsGZmItlsCBYZ0WJBkGVEWUY49ifKcmyfbEGwyDgKCpC+lHszYD6T00SfKofnnnsOi8XCrbee+gaVKE1NfnS9ffNHKBRFktrG/5/tRCKxhLdQKIrfH4kzK9XW1rB16xfceecPueCCWW2Ora6u46mnfsvu3fspKhp8ynOUlo5i+/btbfInmpoa+cEPvg8IPPHEM1gsznZzLEKhaJyMxzlwYD+RSITS0jHtHpcIoVCUhoZTr2r6C1lZyWeFnIkg+XZhcR9BtxdCOERwz060UIjG/NE4oh68Qir14VyIhOKO+2hbNZ/vb2RscQazJuTT0OQjI8XByLxkkhyWOGXQ0tw2Oc27YT2hikryF96Na9KUdmUzjv0BaF/aF/JGgWjr64H0mXQXURQ6fKjus1DW+vp6lixZwvz582lsbKSyspLKykoikQiKolBZWWk6K3vAqlXLMQyDGTMuanf/hRfGtq9c2XHOw8yZs9i5czuhUPyP/ac/vYfq6iouv/yrbNv2BStWvNv6t2PHtk7l27jxUxwOJ1OmTE/wikz6HNUfMydZY6t8PRwitG8PQk4+0aQ0LIYPj31yXN0kiFVZ/Xx/I+OHZTJnUgH+sEJ2mpPxwzJJddkSClX1f74FOT2dpIntm6tMep8+Wzk0NTWhKApPPPEETzzxRJv9l156Kd///ve57777+kC6s59Vq5aTn19AcfGwdvfn5uZRUjKcVatWsGDBHaecZ968r/LHP/4n69d/xKWXXt66/cCBfQD84x9/a3PMV796FWM7se1+8MFqZs++BIejd6ptmpx+ZM9mDEQQY6bC4K4doOtEikZij3gJSwVEpHjzcL07xNovqhiam8zFE/NRNB1JFCgdnIYoJhaNYBgGwd27cU2cZLb2PIP0mXIoLCxs1wn99NNPEwwGWbRokems7IQrrvjaKctU/O1vr3Z6/JIlr3Q6JiMjk3nzruCtt5bFKYePP97UwVEnmDx5apux+/fvY8+eXfzsZ79IaA6TvkeI1CMH96LbCoBYw5zIkcPYS0bQaFhxSs002cZzcviZpuus3lSB3SZz+bQiREHAH1IYNTQdi5x44ILa3IweDGAf1v6Djsnpoc+UQ3JyMnPnzm2zfcmSWCJVe/tM+oZbb/0+8+dfy549u+Iqs3aXf/zjb8yefSnDh4/oBelMTjuGgcW9AUNKbjUZBXduRbDIyCVl6NXVKM58onJ8rsLWA000esJcef4Q7FYZRdWxWSRy0rqW2BatqQLAml/QO9djkhB9Hspq0v/Jy8vngw8+6bX5Fi/+da/NZXL6EUNHESN16I5YcmO0rhalrhbn2IlEEJGNEF5bvBkxEtXYuKeewTkuSgpSAfCHo4wsTNycdJxodQ0A1ry8Xrgak0Tpd8rhpZde6msRTExMjmNoMSe0JRaaahg6wR1fIDqTsA8bjrexHlUeRFSKXzVs3tdARNGYMTbv2HGxOKKstK77mKINdYhOJ3ICmfomvUeXlcO6desoLy/H7Xa3yZwVBIGFCxf2mnAmJiZ9ixQ8hKB6MOyxVUPkSDma14Nr2gUIkkQ40ELQeWmcryGiaGw92MiIwlSyjymDQFglK9XZ2sSnK2huD3Ka2fP5TJOwcjh48CA//OEPKS8vP2U5BVM5mJgMIHQF2fMZuiVWYsVQVYK7tyOnZ2ItKEKN+AhoTjRbfGHGXeXNKKoeVy9JUbVuF9FTPW7k1NTuX4dJt0hYOSxevJja2loWLVrE1KlTSUkxl3gmJgMZKXgAQQthWGK1j0IH9mKEwzinX4ggCCihJlrkcVhOymvQdYOtBxrJH5RETnpMGehGrNVnd/syqF4PDjN44YyTsHLYtm0bt99+OzfddNPplMfExKQ/oEeRPRvRrbFVw/GEN2t+IZbMQaBHCUQlQpYiTu7ufKjGizeocNH4E6uJUFglK9Xerb4MhmGguc2VQ1+Q8KeVlpZGerpp9zMxOReQAvtBj4IYq0cU3B1LeHOOiUUlidFGarRSbLb4DoG7yptJclgozj9hWYiqGtnp3TMp6aEghqoip3beQMqkd0lYOVx55ZWsXr36dMpiYmLSH9AjWDybMKwxn4HqdRMpP4x92HAkVzIYKpoBdUoBVjm+c9uRWh+jBqcjHnNQG0asaU9KUjdNSu5YCR3JXDmccRJWDj/+8Y+x2WwsXLiQDRs2UFFRQXV1dZs/ExOTsxvJvw/DUE+UydgRS3hzlMYSIMVoIz7rKDTREVfOYs/RFgxg9JATFoaoopPitGDrRpQSgOaNKQc5xVQOZ5qEfQ6yLDN8+HD+/Oc/8/77759y3O7du3tFMBMTkz5AC2Pxbmn1NUTrao4lvE1AtNnA0DEMjWaGIZxU+9QwDHaXt5Cf6SQt+URp7FBUZVhB94NX1GPdCCXTrHTGSVg5/O53v+Ovf/0ro0aNYsqUKaSayzwTkwGHFDixajB0neD2LxCTXNiHxaKFhGgjmquM+iYJ20me6NrmIC3+CJNL41vEGoZBWlL3e6loxyozmw7pM0/CyuHNN9/ksssu45lnnjmd8picZfz4xwspKhrMT37yQJePve66rzFp0hR+8YuHANi4cSDcxLsAACAASURBVAOLFv2M//mft0hLM58Uzzha6NiqIeZriJQfQvN5cU2/EEGSwNARjCiKczSeI6HWftAAu8pbkCWBEQUnbuK6biCKAi6Hpc2pEkX1eGLNe5zdc2ibdJ+ElUMoFOLCCwduS82zmaqqSl5++e9s3vwZdXV1iKJAfn4BU6ZM55prrmXIkKGtYx999CHee++d1tcOh5PMzEzKykYzb94VXHBB4p/xF19sYcuWTXHVVauqKvnv/36WPXt209TUiNVqo7h4GN/5zneZMWNmh/NNm3Y+RUVFLF26hIULf5T4G2DSK0j+PYAOogU9GiW4ewfyoKzWgneC0ozmHI5fc6EboVans6Lq7K90M6IwLS4DOhxVyUixd7mW0smoHjdSaqpZqrsPSFg5TJw4kf37959OWUy6wbp1H7F48YPIsoWrrrqKwsKhABw5Us6HH67h9df/ydtvr4pLWrTb7dx//yIAwuEw1dVVrF37AatXr2DWrDk8/PDjyHLnX42XX36J6dPPJy/vREx7Y2MjHo+Hyy//KllZ2UQiEdaufZ+f/exefv7z/+Cqq77e4ZxXX/0Nnn32GW677Xaz18OZRAtg8X2BbomtGkJ7d2FEIySNmxi7MRs6ghZGTR6Pz6sgcKJKwqEaD1FVZ9SQ+FD3iKIzLDU+1LXLYnm8ZhhrH5GwcnjggQdYsGAB06dP5/LLL+/8AJPTTlVVJQ89tIj8/AKefvq/GDw4P67l5l133cMrryxt89QlyzLz5l0Rt+2OOxbyzDO/57XXXuFPf3q20yf35uYmNmxYz89//h9x2ydMmMjTT/9X3LZrr72BBQtu5NVXl3aqHGbNuoSnnvodH364hq9+9aoOx5r0HrJvJxgGiDKaz0f40H5sg4cip8WyowWlGS1pOIY1k0ZPI1bLiVvH7iMtJDstFAxKajNvcjdDWI+jetxYcnJ6NIdJ90hYOTz22GMkJSXxox/9iJycHAoLCxHF+EhYQRBYsmRJrwtp0j5Lly4hFArx4IO/JCMjs81+i8XCTTfdktBcoihyzz0/YfPmz3j99X9y8823kZx86gbsn3yyDk3TmDq18zafoiiSlZXD/v17Ox2bnp5BSclwPv54rakczhCC6kXybUe35WAYBoGtmxFEqTXhDUNH0COoKRPRdJ1mb6Q1b8EfUqio8zO1LDvuIUTVdGRZwGnrWeFn1ePGMWJkj+Yw6R4Jf3KVlZUA5B2rqW7mNPQ969d/TGFhEaNGjemV+URRZO7ceTz//HNs3761Qx/Bjh3bSE/PICsru9394XCYcDhMIOBn3bp/8emn67nssq8kJEdp6SjWrfuoW9dg0nUk3zYQJBAkohVHUBrqSJowGdEeM+uJ0QZU1ygMSzr+QBTdMFr9Dfsq3BjAqMHxJqVwVCMr1dEjX4GuKOiBALIZnNAnJKwcOsptOFv5tGYzn9Rs7GsxuCBvGuflTenSMYGAn8bGBi66aHabfT6fD007EYPudDqxWhNb3hcXlwAxk1VHHDlSHudr+DIvvPBHXnnl70BM6cyadQk/+lFi/cDz8wtobm7C6/WQYiY/nVaEaBOybze6PR89GiWw/XOk9Axsx74H6CpgoCZPAMDtC7c6mA3DYPeRFnIz4nMbIFaFNbOn/gavFzCzo/uKhJRDIBDgBz/4AV/72te4/vrrT7dMJgkQCAQAcDrbOm3vuOMWjh490vp60aLFp+w1/WWOO4GDwUCH47xeDzk5p+7M9fWvf5PzzruApqZGPvxwDZqmoSjRhGQ4bs5yu92mcjidGAayZxOG5ARBJLhzK0YkimvGxQjHKq0KkVqUtPNBdgFQ2xzCYY3dNhrcIZq8YeZMar99Z7Kz+yGscCIBznRI9w0JKYekpCS2b9/O176W2A3mbOG8vCldfmLvLzidMedfMBhqs2/RosWEQiGqqip54onHuzRvKBSKm78jTtXXA6CoaDBFRYMB+MpXruS+++7hgQd+zH//95JOTQ3HpzXDF08vYqQGKXQE3V5ItLqKSPkh7CPKWp3QqH6wpKK5ygAIRVSCYYX05NiKYMfh5lhuQ2G8AldUHYdNxm7tmb9BM5VDn5JwbaVRo0Zx6NCh0ymLSRdwuVxkZg7i8OGDbfaNHTueadPOY8yYsV2e99ChAwAUFhZ2OC4lJRWfz5vwvLNnX8ru3buoqDjS6djj86aaN4XTh6FhaVmPYUlHC4fwb/kMKS0d5+hj3xlDR1RaUNJnghhbAbT4I3BMX0cUjT1HWxhZlNZGCYQiKtnpPQ9DPl50T04zV499QcLK4e677+af//wnGzZsOJ3ymHSBGTNmUllZwa5dO3plPl3XWbNmJXa7nXHjJnY4dsiQodTUJB6UEInEQmz9fn+nY2tqqsnIyDQbSp1GpMA+BLUFXUrCv/lTDF0jeer5CGIsiU2M1KEmj0a3n/Ar1TQGWk1Ke460oGoG44e1jZLTdL11ddETVI8bBAHJ7B3dJyS87nvrrbfIz8/n1ltvpaysjKFDh2K3x38BBEHgscce63UhTdpn/vybWbVqOY8//iv+8IfncLniHcQdmX2+jK7rPPPM7zl8+BDz59+My+XqcPyYMeN4++03qK2tJTc3t3V7S0tLm74fqqqyfPk7WK02hg4d1qkse/fuZuzY8QnLbtJFtAAW92fo1mzC+/egNtSTNGla601YUP0YkhM1dVrrIcGwiicQJd1lQzcMth5sJCfd0aZPg2EYIAg99jcAqO4WpJSUWOkOkzNOwsph2bJlrf/fvXt3u9VXTeVwZikqGszixb/moYd+wfz513HllVcyePAwDEOnqqqKlSvfQ5IkMjMHxR2nqiorVrwLxJ7oq6ur+PDD96msPMqcOXO5/fa7Oj33jBkzkSSJTZs+jUtse+65Z6isrGDKlGlkZ+fQ3NzEqlXLKS8/zF133YOzkxo5LS3NHDx4gOuv/3Y33hGTRJDdmwAD1eMjuGs71vxCbEOKYzt1BUF1E8m5prXRD0C9O4goCAiCwP4KN25/lK+eN7jN3OGoRrrL2q2ub19Gqa/HMiir84Emp4WElcOePXtOpxwm3eSii2azZMkrvPzyS6xb9zHLlr2OKIrk5eUzZ85cvvGN6+JqK0EsB+GRR34JxKKTMjIyGTVqDD/60U8Trq2UkZHJ+efP4IMP1sQph4sumsWyZf/LW2+9jsfjwW53UFpaxve/fxezZs3pdN61a9/HarUya9Ylib8JJgkjhquQA3vRpGx8G1cj2h0kTZrWWiJDjNSgZMxqbfQDsYS2o3V+XA4LhmGwcU896ck2hhe09QWEoxpD8k6dPNkVlMYGHKVlvTKXSdfpWTiBSb+gsLCI++9fhMtliyuf0R6/+MVDrVVQe8q//duN3HvvXVRXV5F/rDjbRRfNbjf3oj1ee+3tNtveeusNrr76m52uMEy6gRbG0vwhqpyO5/Mt6AE/yTPnIFqtYBiIkWrU5PFoSaVxh9W7Q2iajiyJ7CxvpskbZt70onajyQx6VqL7OLqioLa0mCuHPqTLaz/DMNi5cyfLly9n+fLl7Ny5s0u2bZOBw6RJU5g8eWprsltP2bhxAxUVR7jxxlt6ZT6TkzAMZPenKNEwR3YeRa86ijd7KJWqnaiiIUSq0ZwlqGnT4aSbvqJqHKzy4HJYCUdV1u+oIS/TycjCtpFkUUUjyW7Bae/5M6dSVwuGgdWsq9RndOlT/Ne//sXDDz/cpnRGQUEBixcv5qKLLkp4ru3bt/PHP/6RXbt20dTURHJyMmVlZSxcuJDJkyd3RSyTPuSpp57ttbmmTTufVavMshmnAzF4EMm/h8M1MilHdqO60jCGlhKKKFQc2Ut2wShs6RfHymicxKEaL5pmINsFVm6sJBLVmD2xoN1VQzCiMKwdU1N3CB+JhTzbBg/tlflMuk7CymHz5s3cddddOBwObr75ZoYPHw7AgQMHWLZsGT/4wQ/429/+lvCNvaKiAk3TuP7668nKysLn8/H2229z44038vzzz5u9I0xMegkh2oSleS1N4RQcBzcgCBAsmQAIpIuNeGyDWVc/imGWIIXZLmRJxDAMKhr8VNb5yUixs3FPPQervcwcl0dWWvs5DLoBmSk9D2EFCJcfQrDZsJ4UCWdyZhGMBG1CCxYs4ODBg/zzn/8kOzu+2Fp9fT033HADJSUl/PnPf+62MKFQiLlz5zJ27Fj+9Kc/denYpiY/ut7+pfj9blyugZ9QlYjPYSBxtnyuWVnJNDT4+ubkWghb3ZvoQMWmfSTVHiJYMgElMxebVkvQUozbfj6qIeENRJBlkaxUB/6wgscXIdVl5fP9jXyys47SwWlcPrV9X0M4qiJLAlPLem4GMgyDww/ejy2/gIJ7ftzj+dqjTz+TfoIoCmRmnjpkPWGfw9atW7nhhhvaKAaA7Oxsrr/+erZu3do9KY8Ri5zJwOtNPPPWxMTkFBgaluYPQI/gawjhrD1EdFA+SmYudq2GgGUELfYLMAQZSRRIT7bjsMo0ecKoqo5Fllj+aUVMMRSlMXdK+4oBIBhRKczuODcmUYI7d6A2NuKaMrVX5jPpHgmblRRFISnp1PV2XC4XiqJ0WQC/3080GsXtdvPGG2+wb98+Fi5c2OV5TExM4pHdnyGFq9HkbCJbl6Nb7YSGjMau1eC3lOK2TwMh/vlQlkR02WDT3gY+39+AIMDMcXlMGjHolIpBPRbJNCi185IZhmGApmEc+2v9vx77N1pTTf1LS7AMyiJ5+vm98j6YdI+ElUNJSQnvvvsu3/nOd9q0kFRVlffee4+SkpIuC7Bo0SJWrFgBxJrT/Nu//Rt33nlnl+cxMTE5gRg4gOzbhm4vxP/5JoRwkFDZdGw0E7AMa1cxGIbBnqNu1u+oIRBWKR2cxowxuSQ7Oy737gtGGV6YilpVQcN7/0ekshI9HMZQlTZKgASs2HJGJvkL70a09DzL2qT7JKwcvv3tb/Mf//Ef3HLLLXzve99rVQQHDhzgz3/+M1u3buVXv/pVlwVYuHAh3/rWt6itreXNN98kGo2iKErC/QeO05HtTNOCuFw9j70+GzhXrhNA06xkZfVOwtXp5ozKGWmClg2QVUygqo7okcOE84eRnG1HFV0YqbNJFeJvvN5AhDfWHuRorY/8QUncMHckBVkudN1AFIVTm5PCCtm2ZIYnKez81eOIFgspY0YjO52IVguCJCPIEoJ07E+WEUQx9q8kIcoSiLF/BUlGTkkmbcL4M6IYzpbvTl+RsEMa4He/+x1/+ctf2t23YMEC7rsvsWYup0JRFK699lqGDh3KM88806VjTYe06ZDur5xR56cexVb3JqCjGQ48q99Dk2Tqh44nxR6hznUlmhh/U6xrCfLmx4fRNIOLJ+Qzakga3qCCYRhYZBFF0+HYT8tps2C1iAiCQDCsoqgak0qz8P/teYI7dzD0kceQ09LbytXPMB3SnTuku5TncP/993PdddexZs2a1rahRUVFXHLJJRQXF/dMUmJmpUsvvZTnnnuOcDjcprCfiYlJx8ieLaB6Mez5hLZuQQ+H8JROJ9niodl+SRvFUN8SZNlHh7BbJK6eVUx6so0WX5iCLBfFeSlYLRK6YRAMq7j9EeqagrgDUcAgxWllXEkGSTLUbf2C1ItmnRWKwSQxupzKWFxczPe+973TIQsQq/tjGAaBQMBUDiYmXUCI1CH7t6HbClCamwgf2o9laAmqRQF7MWFLUdz4YETlnU+OYLNIXDurhGSnFbc/TF5mEiOK0lr7RIuCgMthweWwUJjlQtN1DIPW4nqBnTswFIWkcWYl3YFEz0sndpPm5uY22/x+PytWrCAvL4/MzLZ14k36Hz/+8UJ+//vfdOvY6677Go8++lDr640bN3DZZRfjdrt7SbpzCF3F2vwvDDkNAwh8sQnR7oDiEYiGits2Oa4shmEYrN5UQSiicuX5Q0h2WokqGrIsMbzwhGJoD0kU46quRo4eBcDejYAUk/5LhyuHX//6112e8N///d8TGnfvvfdis9mYNGkSWVlZ1NTU8Prrr1NbW8vvf//7Lp/3XKaqqpKXX/47mzd/Rl1dHaIokJ9fwJQp07nmmmvjqrI++uhDvPfeO62vHQ4nmZmZlJWNZt68KxKuygrwxRdb2LJlEz/72S9atx05Us7//d+bfPbZp1RVVeJ0OigtHcWCBXdS2kmFzWnTzqeoqIilS5ewcOGPEn8DTJACexFUD7q9gMiRw2geN66p5+MLN+K2jsP4kjlpf5WH8lofF4/Pb+3J4A8pjB2WgUXu2jNjtLoKKS0NKYHWsiZnDx0qh7//PbGCaidHMiSqHK6++mrefPNNXnrpJbxeL8nJyUycOJHf/va3TJ8+PaE5TGDduo9YvPhBZNnCVVddRWHhUCB2k/7wwzW8/vo/efvtVXFd1ex2O/ffvwiImfGqq6tYu/YDVq9ewaxZc3j44cfbhCu3x8svv8T06eeTl3eiydDbb7/BO++8yezZl/CNb1xHIODnzTdf5/bbv8tTTz3L5MkdJzZdffU3ePbZZ7jttttxOHreavKcQAth8WxEt2ZhqCrBXduQ0zOw5ufir6hEcZbF/dAVVedfW6vJTnMwfnhshR5RNOw2OaFchS8Tqa7CllfQSxdj0l/o8A6wZs2aTic4cuQITz31FNu3b+/Sj/m6667juuuuS3i8SVuqqip56KFF5OcX8PTT/8Xgwflx0Up33XUPr7yytE0YoizLzJt3Rdy2O+5YyDPP/J7XXnuFP/3p2U6f3Jubm9iwYT0///l/xG2fO3cet912e1zJ7SuvvJrvfOd6/vKX/+5UOcyadQlPPfU7PvxwDV/96lUdjjWJIft2gKGDaCW0dwdGOIxz+oUQrqfGGI1kif9dbjvYSDAcMycdNx8FwwplQ9IRxVObk06F0lCP/TwzYW2g0eH6saCg4JR/drudF154gdtvv51du3Zx3XXXsXz58jMltwmwdOkSQqEQDz74SzIy2vpoLBYLN910C8nJncdzi6LIPff8hOLiYbz++j/x+ToO8/vkk3VomsbUqfGrvLKyUW16MaSmpjFhwkSOHCnvVI709AxKSobz8cdrOx1rAqj+WLKbLRs9HCK0fw/WgiIs6SlENBm/NDTu4SCqaGze18CQnGTyMmNmIO1YLkN3Vg16JIIeDGJJz+i1SzLpH3TZIR0MBvnP//xPLrvsMl5++WVmzZrFW2+9xa9//WtyzNrrZ5T16z+msLCIUaPG9Mp8oigyd+48IpEI27d3XCdrx45tpKdnkJXVttZWezQ3N5GamlhOQmnpKLZv35bQ2HMd2b8zluksSIT27QFdxzl6HEK0kUZ5DIYYnxS543Az4ajGeaNP/FaDYYW8jKQu+xog1ucZMENYByAJh7Kqqsorr7zCc889R1NTE5MnT+a+++4zey/0EYGAn8bGhna7rvl8PjRNa33tdDoTzjgvLo5FnFRVVXY47siR8jhfQ0ds3fo5O3Zs59Zbv5/Q+Pz8Apqbm/B6PaSk9E5/gAGJFkD270S3xlYN4cMHsRUNQXI6EJQgtZECbJYT/Rl0w2DboSbyByWRm3FidadoOjkZ3fPvqC3HlEO6qRwGGgkph3fffZenn36ao0ePUlJSwq9+9SsuvfTS0y3bace7fh2ej//V12KQOvNiUmZ0rX9FIBAAwOls+6O+445bOHr0SOvrRYsWc8UVX0to3uN+o2Aw0OE4r9dDTk5ep/O1tDTz8MP/TkFBId/+9k0JyXDcDOZ2u03l0AGSf18sc1mQCO3bDYaOo3QMYrSBaPIEWhoFkp0nlMORWh/eQJQZY0/0SFA1HasskpzUtXI1rcebymHA0qFy+OSTT3jiiSfYtWsX2dnZPPLII1x77bWIYp+lR5gcw3ksbDAYDLXZt2jRYkKhEFVVlTzxxONdmjcUCsXN3xGdVV4JhUL87Gf3EgqFePLJ/0w4YOH4tKeq52MC6BEsvm3o1iz00PFVw1CkJCdEPPgtw9D1YFy+wraDTSTZZUryTyjcQFilMMvZYV5DR5hmpYFLh8rh1ltvRRAExo4dy0033YTdbmf16tUdTnj55Zf3qoCnk5QZF3b5ib2/4HK5yMwcxOHDB9vsGzs2lqmaltb1ukOHDh0AoLCwsMNxKSmp+Hyn7ruhKAq/+MX9HDx4kKee+v8oLh6WsAzH503UR3EuIgXLMQwFRJnQ/u1gGDhKRyMoTaiuUfgVO3Bi9ecLRjlS52P6qGykkyKSdF3vliP6OGpLC6LDgWhWMxhwdGpWMgyD7du388ADD3Q6ThAEdu/e3WvCmXTMjBkzefvtN9i1awejR4/t8Xy6rrNmzUrsdjvjxk3scOyQIUP56KP2I4p0XefXv/4lmzdv5JFHfsOECZO6JEdNTTUZGZlxuRkmJ2HoyN7PMSwZ6NEo4fJDWAsHIyUlIUTcaElluOsicVnM+ypiWedlg0884Wu6gSQJnZbk7gjV40Y2lfiApEPl8PjjXTNJmJxZ5s+/mVWrlvP447/iD394Dpcr3kHchYK76LrOM8/8nsOHDzF//s24XB139RozZhxvv/0GtbW15H6pz+9TT/2ONWtWcf/9i7j44tkJy3CcvXt3t65+TNoiRmoQVD+Go4DIgd2gqTiGlyKoXjRbAYY1k2ZvLTbrCX/DnqNucjOcpJ1U0j0UUclKc3Qrt+E4mteLZCrxAUmHyuEb3/jGmZLDpBsUFQ1m8eJf89BDv2D+/Ou48sorGTx4GIahU1VVxcqV7yFJEpmZg+KOU1WVFSveBSASiVBdXcWHH75PZeVR5syZy+2339XpuWfMmIkkSWza9ClXXfX11u3//Oc/WLbsfxg7djx2u731PMf5cvLdl2lpaebgwQNcf/23E30bzjkk3w4MOQlD0wgd2oclKwc5LR0hVIWWMRNF1QhFVNKTY6aeRk+IJm+YWRPjHx4UVSMrrWdZ6KrXi61ocI/mMOmfdLkqq0n/4qKLZrNkySu8/PJLrFv3McuWvY4oiuTl5TNnzly+8Y3r4morQaxkxiOP/BI43rc7k1GjxvCjH/004dpKGRmZnH/+DD74YE2ccti/fx8Qy4PYsaNtrkJnymHt2vexWq3MmnVJQnKcawiKBylcgW7LJ3K0HCMcxj75PNDCGLIL3ZZPIBDfrnfvUTeiACMKT5h/jq8qU7sZpXQczetBTjGb5gxEutTspz9jNvs5881+Pv98M/feexcvv/w6+fm9U1vntttuZNKkKdx99487HXu2fK692VhG8mzG4tuGZs3Bs2Y5CAKpl8xDjFSjps9Ec5VRWe/nQJWHNJcNwzD4y3t7yEq1c/WFJ3quhKMqFovElJFZ3ZZFVxQO/OD7ZF7zTTKvuro3Lu+MYTb76bzZjxmTatJtJk2awuTJU3nllcQKNHbGxo0bqKg4wo033tIr8w04dDWW9GbJRKmvRfN5cYwoRUBDQEJzDAWgyRtuTX6rbAgQCClxjmiI+Rty0ntmUtKORZWZPoeBiWlWMukRTz31bK/NNW3a+axa9VGvzTfQECPVCHoUQ7QQPnwQwWbDWjgYIdqImjwaJDu6YeD2R0h2xMxFeytasMgixXltb+BpPew3rnljykE2ExUHJObKwcTkLCHmiE5GCwVRaquxDRmGIIgIhoKWNAKAYFhFN2KF9FRN50CVh5L81Li6SZquI8siTnvPng1VrycmVwKFHU3OPkzlYGJyFiAoHqRINYaUTKT8EBgG9qHDToSvWmJVUf3BKBix0NQjtT6iik5pUbxfJhg+FsLawwx0zRuz2Zsrh4FJt5RDNBqlrq6OaDTa2/KYmJi0gxgqB0QMwyBy5BCW7FykJBeC5kNLHtc6rtkbwWqJ/az3Vbpx2CSKsuOdjoqmMyi15xnN2vGVg+lzGJB0STns3LmTm2++mcmTJzN79mw2b94MQFNTE9/97ndZv379aRHSxOScxtCQ/dvRrZkodTXooRC24pJY+KqUhG6P5S/ohkGTL4zdKhFVNA5VexlRkBaX5GYYBgKQ0oOs6OOoXi+CzY5o65nvwqR/krBy2L17N9/5zneoqKjg61//ety+zMxMIpEIy5Yt63UBe4sBErFrcoxz6fMUI3UIahhEa8wRbbdjzc1HVJpRXeNBiEUmhSIqqmogiSKHarxousHIL5mUIopGSpIV60mlvLuL5vWaOQ4DmISVwx/+8Aeys7N55513+OlPf9rmx3n++eezbVv/bNAiCBK6rnU+0OSsQdc1BOHccJlJ/t0YsgMtGECpq8E+ZBiCAAgCWtKJgoaewAkz796jbpKdFvIy47vyhSIqORnx27qL2tJsVmMdwCT869q8eTPXX389SUlJ7ZZSzs/Pp76+vleF6y2sVhuhUJBoNIKu6+fUU+dAwzAMNE0lHA5itZ4DlUC1IFKoHENOizmiEbANHYagNKM6R4B04kbf6A5hs0oEwgoV9T5GFqa1+a0a9DyE9ThKSzNyO+1pTQYGCceyRSKRDnsR+/3+XhHodGCxWBFFiWg0jKJEMAy9r0U6LWialVBo4AcJCIKI1WrHYum53by/I4WOYBDrcREuP4QlJxfJmYQQbkFzlbWOUzWdZm+E1CQrm/bWoxswemh8X2dF1bFZJJJ6GMIKYOg6aksLcobZO3qgkvC3ZPDgwezcufOU+zds2MDw4cN7RajTgSRJOBydN7A5mzFLAgwwDAPZtxPDkka0phojEsZeXAKqH92ShWE5UVDRG4iiGwYGsT7RRVku0pPjVwjBiEJRdnKvNFHSvF7QNCymchiwJGxWuuqqq3jzzTfjIpKOf8n+8pe/8NFHH7VxVJuYmHQfQWlCUFtAchIpP4jocGLJzUNU3ajJ4+Gkm3xdSxCLJHKk1ocvqDCupK25R9fplRBWAKW5GQA53VQOA5WEVw633XYb69atY8GCBQwbNgxBEHj88cdpbm6msbGRGTNmMH/+/NMpq4nJOYUU2I8hWNH8fpT6WhyjxiIYGghWdEdRqirrWwAAIABJREFU6zhV06lvCZHssPLB51Uk2eU25TIUVcdqEXE5Lb0im1JXA4A1J6dX5jPpfyS8crBarbz44os88MAD2Gw2bDYb5eXlpKenc//99/OnP/3J7C1tYtJb6FHkwD4Mawbh8oMgCNiGFCMqTSjJY0E8cZNv9obRdANfSKG81seYoRlxrUABAmGFgqykHmdFHydSXQ2ShCUru1fmM+l/dMkzJcsyt9xyC7fcckuPT7xt2zaWLVvGp59+SnV1NWlpaUyaNIl7772XIUOG9Hh+E5OzGTFcBYaCYQhEjhzGkpuPZHdApBndecK3ZxgGh2t8OG0yW/Y1IABjiuNNPYZhoBsG2T1s7HMy0apKrDk5CLJZu3Og0mef7AsvvMCWLVv4yle+QmlpKQ0NDSxdupRrrrmG11577f9v787Dm6rzBf6/z0nSpE13aAuUrRRadmQTWfyNMuiwCOpFGB1FZRTljvc3Lo+OyzijzzhzQcHrwoyPj3hF8aLjAgwqP0UFXFEYUQERlB1Ka7e0SZdsJ+f7+6M0UFOgQEpK+nk9T5+255x880lOkk/OdyU/Pz9WoQkRc5ba71HWFALFh1EBP468fDTDTcjeFWU7OpeRy+On1hsgPdnO9v1V5HVOjVgT2us3yEx1kOSITpWSMk28e/eQPPjE64yLc1uL64GefvppLrvssuPunzp1Ks8880yL7/jGG29k3bp1PPjgg8yYMYPf/e53LFu2DMMwWLx4cYvLESLeHDvJnm/fHvQkJ7bsTmihWkKpR+dRMk3FrsNunA4bew578PoNBvaKbIj2Bgy6Z594TfBT4S86hFlbS2JBYdTKFG1Pi5PDBx98wJgxY467f+zYsaxZs6bFdzxs2DASEpp+w+nZsyd9+vRhz549LS5HiHjTMMmehVBtDUZFWcOgNxVAWZIw7Z3Dx/1UWU+9L4gjwcq2vZWkOhPokdM0CdT7DdKcCRHdWs+E57NPwWIheYhcOcSzFieHoqIievXqddz9eXl5FBUVnVEwSikqKirIyJAh+aKdOmaSvcaGaEePPPRA03mUgkaI3cVuUpMSqPT4OFxRx6C8zCZjGJRS+PwGvZsZKX1aoZkmNV9tovrj9aSOHiPrOMS5U2pz8BxZ+ak5brcb0zyzkcdvvfUWpaWl3HnnydcPFiIeNU6yZ+rp+A/sJ6FzLrrdjvKbhJKOrgF9qKwO01RYLTrf7a1E1zX6/WxEdHWtn27Zyac9XYZRXU31R2vxHziAUV1NoKwM5fdh796DrKt+fUaPU7R9LU4Offr0Yd26ddxyyy0R+5RSrFu3jry8vGZu2TJ79uzhL3/5C8OHDz+twXQnWii7PcnKkm9zbVGLz0vJAUjPoOZwKSoYIHNAf5IcPsjoD50bqpT8wRCu3RV07ZyKacIPh6rp1yOTztlH78Pl8dE9N50R/XKwWk69i7m/spItf3uYoNuDs0cPkjplkTGoP6n9+tFhzAXocdBLSd4rJ9biM3zVVVfx5z//mfvuu48//OEPZB4ZNu9yuViwYAFbtmzhT3/602kFUV5ezq233kpaWhpPPfXUaY2XqKysxTTb94R6Mn1G29Ti8xKqw1GyHdPeGff3O9CdyQSc6YTcxQQSxmAeKeNgWQ01NX6sCnYcqMIXCFHQNQ2320vIVFTX+clKc9C9QxJVrrrTirl06SsYNbX0+NPD2Lt1b7Kvssp7WmW2JfJeAV3XTvilusXJYebMmWzatIl//etfrFq1iqysLKDhg10pxeTJk09rhHRNTQ1z5syhpqaGV199NVyuEO2NxXsA0DBqajAqK0gaMATN9KMsyZj2hpHIpqk4WFpL8pFuqdv3u0hzJtA1y0nQMPHU+cnvmkb3nJTTHvCmDAPPxi9IuWB0RGIQ7ccpXRsuXLiQ8ePH8/bbb3Pw4EEABg0axNSpU5k4ceIp37nf72fu3Lns37+fF1988YQN3kLENWVi9WzFtGXi/2E76Dr2Hj3Rgy6CGaPhyNoV7roAgWCIZIcNl8dHcUUdYwd2wlTgqfMzML8DORlntl6Db99elN+PU8YxtGunXHE4efJkJk+efMZ3HAqFuOOOO/j222955plnOO88eSGK9ksPlIFRi7Il4T94gIQuXdETEsAPocSjMwaUVNaRYG3osbTzYBWaBv16ZDRcMeSmnXFiAPDu3g1AkoxjaNdi1qo0f/581q1bx8UXX0x1dTWrVq0K73M6nUyYMCFWoQlx1llqd4DFgb/oIMoI4sjrjRasJpTUCywNU80bIZOyai+piQ3jg/YUe8jtmIzNasEEukZpoFvgpxIsaWlYkqWTR3t2yslh27ZtbN26tdmuq5qmcdttt7WonJ07dwKwfv161q9f32Rfbm6uJAfRfoTqsdTvJZSQg2/fZiypaVg7dARfMaHkfuHDPHUBzJBC1zVcHh9VNX4G9+pArS9In65pp9UrqTmBn0pI6NT55AeKuNbi5ODz+fiv//ovPv/8c5RSaJoWXm6z8e9TSQ4vv/zy6UUsRJyxePcDDeMKQtVVOIcMQzN9YEvFTDg662lZtRebtSEB7CluGHPUq3MqhmmSFc1J9UpKSBl5ftTKE+emFn/V+Mc//sHnn3/O3LlzWbp0KUop5s+fz+LFixkxYgSDBg1i9erVrRmrEPFHmVg9WxoaovftBouVhG490YJVRxb0aXiLmkpRXlVP0pElPvcWu8nJSMRi0clMdWC3WaISjunzYtbXYesovQbbuxYnhzVr1jBx4kRuv/12+vTpA0BOTg4XXnghS5YsIRgMsnLlylYLVIh4pPtL0Iw6zJCGv+gQ9m490K06GlqThuhabxAjBBZdp9YbpLTKS68uafiDBp0yz7wRupFRXQ2ANSM9amWKc1OLk0NJSQkjR44EGtZjBggGg0DDOg9TpkyRKwchTpGl5juU1Yn/wD4wQzh65aMFXRjJhWA5WlVUXesPrwq6p9gNQH6XVBSQlpzQTMmnJ5wc0mV+s/auxcnB6XQSCoXCf+u6TllZWXh/SkoKFRUV0Y9QiDilBaux+A5i6in49uzC2jEba1oGWshPyNm0G2m5y0tiwpEqpcMeMlLsJCfacDpsOBKi1+nQqK4CwJouVw7tXYuTQ/fu3dm/fz/QcOXQu3fv8BTdSik++OADOneWHg5CtJSl7kfQrARKDmN660nsXYBm1GDas1G2o+syBI0QnvoACTYdX8CgqKKWXl1S8foNcjKi1xANYLgbrkosaZIc2rsWJ4fRo0ezZs2a8NXDr3/9az799FMmTJjApZdeyoYNG5g+fXqrBSpEXAn5sNZsJ2TrgHf3D+jOZGyduqAF3Ucaoo9OfVFT31B9q2ka+0pqUAryu6RhKkXaac64ejxGdTWa3Y7ucES1XHHuafH16C233MLll18e7r567bXXEggEeOutt9B1nTvvvJM5c+a0WqBCxBNL/R4UJkZVNaEqF84hw9FUEGVJxHR0a3Ksy+PDcmQyyr3FbpyJNrLTHXjqAyQnRmfpz0ah6iqs6dFZ/0Gc21qcHJxOZ8TcR7Nnz2b27NlRD0qIuGYaWD3foBI64P3232i2BOzde6IHygimjQK96duywu0j0W4laJgcKK2hf49MgiFFcqItPO4hWozqaqxSpSRoYbVSXV0dEyZM4MUXX2zlcISIf7p3P5rpw6ipJ1hyGEd+nyMLvOmEnPlNjvX6Dbx+A5tV52BpDUZIkZ+bis9v0DEtuu0N0NDmII3RAlqYHJxOJ9XV1TidztaOR4j4pkLY3F9h2jLw7vwezWrDkV+AHqjESBnYpPsqNIxvaLSn2IPdZqFLx+RWaW+AhuRgSU2Lerni3NPia9IhQ4awbdu21oxFiLin1x9AC9Vg1AYIFBfhyO+DbrOilEEouW/E8RVuLzarhZCp2FfiIa9zKha9oT0gOTG682aafj/K78OamhrVcsW5qcXJ4e677+a9995j+fLl4UZpIcQpUCFs7k2Ytky8O7ejWa04ehegBcoJJfdDWZsuW2kqRUW1l0S7heKKWvzBEPldUgkYIZIcNmzW6EyZ0Sh0ZI14uXIQcJIG6eLiYjIzM3E4HMybN4/U1FQefPBBFixYQPfu3XH8rLubpmm89NJLrRqwEOcqS/1etFANAY+DQHERiX0HoNts4A8RSh4YcXy9z8AIKSy6zp5iD1aLRvecFLx+gy4dozdlRiPDc2SMg1w5CE6SHH75y1+yYMECLrvsMoqKigDCA91kNLQQp8AMYK3eSMjagfptn6M5HCT26YseKMdI7oeyRX5br671Aw2DTPccdtMjJwWbVafGa5KREv1xCI1XDla5chCcJDkopcJVSOvWrTsrAQkRjyw128H0Eyirw6iqxDl0ZMOEqyHVMOitGWVVXhLtVn5y1VPnM+id2/ChrQHOKLc3ABjhaiW5chCn0OYghDhNATdWz9eE9Azqtn2LJS0de4+eaIFSgqnDwBq54logGMJd68dus7CryI2ua/TsnErQMLEnWKM6n1Kj0JFqJWmQFiDJQYjWpRSUfw56AvXfb0f5fCQPHdmwmI/F2WSlt2N56gKoI4OUdx920yMnGbvNgi9g0DGtdaa2MDwe9CQnmjVmqweLNuSkr4KvvvoqPJ9SS1xxxRVnFJAQ8USv3wOBfQQ8Cv++PTjyC7CmZ6D7ighkTQS9+em2f3LVY7dY+MlVT603yOgBOQAEQyaZqdEf3wANVw5y1SAanTQ5vP7667z++usnLahxmVBJDkI00AwPCVWfEUrKpPbf76I7k0nqPxA9UEbI2QczsXuztzNCJhVuH6nOBDbuKMVq0ejV5Wh7Q0pi9NZvaHK/bre0N4iwkyaHmTNnct55552NWISIH6aBrfJjTCyUf7kJM+An7RcT0AigNCvB9AuOe9PqGj+mUoRCih8OVdOnazp2m4WAESLRbsWeEN3xDY0Ml4vEwsKTHyjahZMmhxEjRjB16tSzEYsQ8UEprO5NaIFSandX4CsqImnwMKypKej+EgI50yKmyTjW4Yo6HDYruw+7CRom/Xs0rMrm9Rl0y0k57u3OKORQCKO6CluHDic/WLQL0iAtRJRZar7DWvMd3uJ6fLt2klJQiCOvF7q/mGDGWEx7p+Pe1us3qPT4cCTofLOrnIwUO106NsxpZipFh1ZqbzDc1WCaWDMlOYgGkhyEiCJL7U5s1RuoL/FSt+VrbJ260PH8kVj8xRgpgwkl9z/h7Usq69A1jaLyOircPoYVZKFpGiFTYdE1kpOiu35DI6PSBYBNkoM4QpKDENGgFBbPNqyVH1N3wEPdlm+wdepCysgL0PzFGCn9MdJHNVnh7ecCwRAHS2tJTrTy5felOB1WCrs1TJ9d7wuSnZkUXvQn2gJlpQDYOnZslfLFueeEbQ47d+48W3EIce4yg1jdm9CrtuDZUUzgcBEJXbuTPHQolmAJdB6LofrTMCT6+IrKawHF3uIafnLV88thXbFaGm4TDJnkZER/PqVGgeLDaFYrtqzsVrsPcW6R0S5CnAEtUEGC62MCxXtxb9+L6fWRNGAwiT07oRmVBDtcDFnDobzmhOXUeoPs/6mGBIvOx1uKyUp30K9nQ0N00DBJsFlIc7ZOF1ZoSA4JnTujWVqnJ5Q498Q0OZSVlbF06VK2bNnCd999R319PUuXLmXUqFGxDEuIkwvVYfVsQxV9jnt3CcHyCiwpqaSOG449RWFanQQyJ6JsmSctygiZfL/fhU3XeP+rQwSCIS79f3qhH6mCqvUGye+aiq63zrrOyjTx7duHc/CQVilfnJtimhz27dvH4sWL6dGjB4WFhXzzzTexDEeIE1MKLehCr95GaO8X1BwqwajyoCUkkNS/kKSuHSDBSSDtfMykvJNWI8HRxOCuDfDF9p8oKq/jkhHd6JDqCO/Xdeic2YpVSoeLCNXWkNS3+ak8RPsU0+QwYMAAvvzySzIyMvjwww+57bbbYhmOEJHMIHhLUT9tQ5VsIVD6E0GXu6EB2plEUt88ErvmoJK7EkweiJnYjSMLQp9UrTfIjv0ufixy8/UP5VTX+rnovFz6HRnXAOCuC9C3e3rUF/Y5lueLDWCxkDQgck0J0X7FNDkkJ0fORinE2aTMEMpXi6qvBG8V1LtQdRWY7mLMmnLMWjehOi8cWfzQ4kwksWcu9pyOaJ37o5J6EbTnRKzidjxBI0RplZft+1zsPFjFwdJaqmr8pDoTuOLCPLplN5SjlKK6LkBWuoPOHVtv7Xbvnt1Ur19LyvCRWNNkHQdxlDRIi5gIGiH2Fns4VN7w4VjnDWKEFKapMJUCI0CqUUFiqIZEVYsjVIdFBbFgYFEhLMpAVyF0FDohdGWiYWJRIXTMhh/V8NtCCE0pLJgNx6KObG/4aTY+LLhx4iaDCvIo1bIoIYdabwrmAQvqQMM3eaUqUFSggMzaCjp7inAE67GEjHBZGmCaJgowDDO8RkpnoFeChXRnAmlGAvqmb1Gq4fErU9EpwUKa00bpesLJCdSRvxUohWr8uyGYo78VqGa3H/07WFVFoOgQto5ZZM28+gzPqIg3cZMcOnSQqxCArKzWmV4hWvYerub/3t3Jt7vKCRpHP5gtmkn/hBL62YroYymho16DrkWuVW4oHaMhRRBCJ6QaPu4bP/ZD6BjohLA22W42/q1ZCGFpSCmaBQMrPhzUaw68JOLVEqkniXrNiabroGk0NgNrmoYFsGg02YZSDN77GYVF3wIQ0i0YlqOD1RRHytA0NK3hNpquYdF1ND8ovwauxv0aut7wY9F1glrDnWmaRvheNY6Ml9CO/Gq6T2u4k8YAj8aJ1uS2Sdkd6fSLcXSa9CtsKW37ddMa2vp7JdbiJjlUVtZimpEfJu1JVlYK5SfpMhkrIdNk7VdFLP9kLyFTMaBnBiP7ZdM7w0fa/ncw936H6QuARcfWMQc9ewh6hzy01C5oSR3QElPAmoDWgkbes632m68p/uRb0n5xMR2uuBJrStOZTdvyeQGo9gG+thtfa2jr5+Rs0HXthF+q4yY5iLbLVIr1Xxfxxkd7SEmy8bsrB9E7xwK7VlH/0ScY9X6smRk4Rk5Dzx+PltB6PXNaQ9X772HLziH7N9fJOAERNyQ5iFa3v8TNW58fwJFg4a5fn0c3ZzXGp89Tv2s/liQHzl9cid5nMuitM29QazKqq/Hu3kWHaVdIYhBxRZKDaFX+QIh/fbqfWm+Q639VSHdHEf6PXsBXVIY9Nwf7L25DJTe/6M25wLvrR1AK56DBsQ5FiKiS5CBa1Y9FVew8WEVe5xQuzPPg+/gF/MXlJPbOwzru/0UlnHwEcVvm278PzWrF3rVbrEMRIqpinhyeeeYZAPbs2QPAqlWr2Lx5M6mpqVx33XWxDE2coaARYu3mwxghxdShdvjq//AXl5PUpyfWcb9H2TJOXkgb5zuwn4Su3dCsMX8rCRFVMX9FP/XUU03+X758OQC5ubmSHM5xpVVedhVV061jAoNq36Z+72Ec3XKwjP7PuEgMAIGSYqlSEnEp5snhhx9+iHUIopV8ub0Urz/Epb13Ub9jL7bMVOzjfovpyIl1aFFhBoOE3G5ZIEfEpbbXaVzEhTpfkO/3u0ixBhjs3oxm0UkaPQUzuSDWoUWNUV0FIEtrirgkyUG0itKqeorKavhNxhdQ7yVl6BDMzhedcCW0c41RWQmArYMkBxF/JDmIVvHtzmJytXL6hQ7g6JaD1vcq0O2xDiuqDFfDusvWjHO7x5UQzZHkIKLO6zcoLtrDb5I3oNkTcAyfgmnvFOuwoi7oarhysGZKchDxR5KDiLpa137yPNvpZHHjHNifUMf4XNnPcLmwJKegJ7Te8p1CxIokBxFdZpCq799nrHUnJfZOWPv/R9xVJzUKulxy1SDiliQHEV3u73Ds34lXJWAdMBLTEb8jhw1XpSQHEbckOYio0QwPgW1vkxHysNYYTFbBRXHVO+nnjCqXjHEQcSvmg+BEnFAKvWQ9vl0H2B3MwZ3ZF2dy/H6rDtXXY3q9WKUbq4hTcuUgokL3HcL77aeokMnrdRfQO78Xuh7HVw1HeirZpBuriFOSHMSZMwOoXW/hL6lgq96Laj2dwX3iY4qM4wk2jnGQKwcRpyQ5iDOmV39N7dbtaIkOlnvOp3OHZNKd8d29s/HKQQbAiXglyUGcES1QSfCbdzDrvRzuWIAnYCOvcwqJ9vhuzjJcLtB1rOnpsQ5FiFYhyUGcPhVC2/sW9XsPY++SxdqaEWjAsILsWEfW6oKuSqzpGWi6vIVEfJJXtjhtevUWar/+N3qCDQZeyN5yCx3TE+ma7Yx1aK3OcLlkwj0R1yQ5iNOiBSoJbF5OqLaelMF92WUMw1Xjp3u2k5QkW6zDa3XBygqZqlvENUkO4tSZAdjxGt69h3F0zYHC6Wz8oQaAwfkdscR5VYsKhTCqqrB17BjrUIRoNfH9LhbRpxR68Tpqvv4aS0oSjvMvo1bP5ceialKdCfTrER/Lf56IUV0FpindWEVck+QgTonu/o66z98BU5EyciyhzAvYW+KmrMpLXqcU0lPic5K9YwXDi/zIlYOIX5IcRItp9UV4P16C4a4l+bwBmD2noTQrn28rAWBE32yslvh/SRkVFYAkBxHf4v+dLKLDX0Hgk2cIlLpw9s9HG3Q9yppCdV2A7fuqyEp30L9n+xgQFigrBU2TaiUR1yQ5iJPzlRNc9zi+g8Uk5uViHXEzKqHhW/PnW0uo9QYZmNeBtOT4HhXdKFBSjC07B90W/72yRPsV38NYxRnT6g7hX7cIf0kZib27Yxs9F9PRGYB6X5DPtpXgSLDwi6Fd0ON4eu5jBQ4fxt4lN9ZhCNGqJDmI5ikFpZuo/2gphqeOpL69sV4wN3zFAPDRt4cpq/JywYAcunSI/4FvAGYgQKCslOThI2IdihCtSpKDiKCMWsxv/g/v1k2gaSSPGos24BqUNTl8TIXby/v/LiI50cakC7q3i4ZoAN/ePWCaOPLzYx2KEK0qpskhEAjw1FNPsWrVKjweD3379uXOO+9k9OjRsQyr3VKhIGrvh/g3r8bw1GLrkI5jzEzodAFoRz/8jZDJi+/uxFMX4PJxPcntmHyCUuOLd9ePACTm94lxJEK0rpgmh/vuu4/333+f66+/nh49erBy5UrmzJnDyy+/zNChQ2MZWruivFWEfnyfwI5PCXlq0R0JJI38BZaB08GW2uTYkGmy5P/bwff7qxjYK5Nfnd+93bQ1ANRs/gpHr3wszvZRjSbar5glh61bt7J69Wruv/9+brzxRgCuuOIKLrvsMhYuXMiyZctiFVrcU8rErNiLWfwtof2bCZb9BEphSU4iafgvsAyYBo7Ibpout4/Fq7/nh4PV9M5N5eYp/XEktJ+aSe+uHwkUHSLrN9fFOhQhWl3M3tnvvfceNpuNGTNmhLfZ7XauuuoqnnjiCcrKysjOjv+pn1uLMkMoXw2qthJVU4Ly/ITpOoBZVUzI40YZBgC6w4699wCs+WPQckeiWZp2z/QHQ2zf5+LL7T/x7e4KQqZiVP8cZl1aQJKj/XTlDFZW8tOLL2BJTydt7IWxDkeIVhez5LBjxw7y8vJw/uzyfPDgwSil2LFjxyklh8+fn0dddcO0BqgoBKiO+89JHbeSRR2nrOMWr46Up0Ad+Y06Ur46sl2hY6IphRb+fWRfRGkahmbF0JwEdTsBSyKhmgQo98PX61FqHSFTHf0JmRihhnKcGlzqsJKVnoizysb3r31w/MevzuAEnPCmJ9h5urc7yW7NCGGtdGM/UIKyWKi89lccLPv3icv7meQqO7W1/lO6jWhd8XJONE1jePYQUhKi3+4Xs+RQXl5OTk7kOsNZWVkAlJWVnVJ5XXZX4i8rj0ps8S0IeJtsOdFHpzrN5oSTpocTlHvaqaUVygzpGu4UC8W97XxbmITHvwl2nWZhQrSCzpmZjMs9P+rlxiw5+Hw+bM2MMLXbGyZu8/tPLat3eOB+jCNVJXDs54QGRxpMtWM/PbSIA8MbwpuOaWjVft7o2vj/cT+Qmt+haVqTck/JCW6naRodOiZTWVF7emWLExoOTD3N28p5aXvi5ZxomkaiNZHy8ppTvq2ua3TocPwrjpglB4fDQTAYjNjemBQak0RLpaZ2wDSjUZ907kpOcOK1mbEOQ/yMnJe2R87JycVs5FJWVlazVUfl5Q1VQ9IYLYQQsROz5NC3b1/27dtHXV1dk+1btmwJ7xdCCBEbMUsOEydOJBgM8sYbb4S3BQIBVqxYwbBhw5ptrBZCCHF2xKzNYciQIUycOJGFCxdSXl5O9+7dWblyJcXFxcybNy9WYQkhhCDG02c89thjPPnkk6xatQq3201hYSHPPfccw4cPj2VYQgjR7mlKncmIpbajsrK23fdWyspKOa0ubaJ1yXlpe+SctOGurNGm6+1n8rcTkeehbZLz0va093NysscfN1cOQgghoqd9rNAihBDilEhyEEIIEUGSgxBCiAiSHIQQQkSQ5CCEECKCJAchhBARJDkIIYSIIMlBCCFEBEkO7cjTTz/N5MmT6du3L6tXr451OOKIhx56iHHjxjFs2DCmTp3K+vXrYx1Suzdr1iwGDRrE0KFDGTp0KDfffHOsQzrr4mb6DHFyPXr04I9//CNPPfVUrEMRx7j++ut54IEHsNvtbNu2jdmzZ7N27VrS0tJiHVq7Nn/+fKZMmRLrMGJGrhzakcsvv5yxY8ee8hKsonXl5+c3OSeBQCC8IqIQsSLJoY0qKytj4cKFzJo1i6FDh1JYWMjGjRubPTYQCLBgwQLGjRvH4MGDmTlzJl988cVZjrh9aK3z8vDDDzN48GCuuuoqxowZQ35+fms+jLjSWufkkUce4YILLmD27Nns3LmzNR9CmyTJoY3at28fixcvprS0lMLCwhMee9999/HSSy8xbdo0/vjHP6LrOnPmzOGbb745S9G2H611Xh5++GG++eYblixZwujRo9G09j1j6KlojXNyzz2RQrgXAAAOj0lEQVT3sHbtWj766CPGjBnDLbfcErGkcdxTok2qqalRLpdLKaXUBx98oAoKCtSXX34ZcdyWLVtUQUGBWrJkSXibz+dTEyZMUL/5zW+aLfu6665T77zzTqvEHe9a87w0uvXWW9Unn3wS1bjj2dk4J7/61a/Uhg0bohp3WydXDm1UcnIyGRkZJz3uvffew2azMWPGjPA2u93OVVddxebNmykrK2vNMNuds3FeDMPg4MGDUYm3PTgb50TX299HZft7xHFmx44d5OXl4XQ6m2wfPHgwSil27NgR3hYMBvH7/Zim2eRvEX0tPS91dXWsWrWKuro6DMNgzZo1bNy4kREjRsQi7LjW0nPi8Xj4/PPPCQQCBAIBXnzxRTweD4MGDYpF2DEjXVnPceXl5eTk5ERsz8rKAmjybehPf/oTK1euBOCrr77i3nvvZenSpYwaNersBNuOtPS8aJrG8uXLeeSRR1BK0aNHD/7nf/7npHXn4tS19JwYhsHjjz/Ovn37sNls9OvXj8WLF5OcfPwlNeORJIdznM/nw2azRWxv7Brp9/vD2+bPn8/8+fPPWmztWUvPS1JSEkuXLj2rsbVXLT0nmZmZrFix4qzG1hZJtdI5zuFwEAwGI7Y3vtBlTENsyHlpe+ScnBpJDue4rKysZhvSGgdRZWdnn+2QBHJe2iI5J6dGksM5rm/fvuzbty+iD/aWLVvC+8XZJ+el7ZFzcmokOZzjJk6cSDAY5I033ghvCwQCrFixgmHDhjXbACdan5yXtkfOyamRBuk27JlnngFgz549AKxatYrNmzeTmprKddddB8CQIUOYOHEiCxcupLy8nO7du7Ny5UqKi4uZN29ezGKPZ3Je2h45J9GnKaVUrIMQzTted8bc3FzWrVsX/t/v9/Pkk0/y9ttv43a7KSws5K677mLMmDFnK9R2Rc5L2yPnJPokOQghhIggbQ5CCCEiSHIQQggRQZKDEEKICJIchBBCRJDkIIQQIoIkByGEEBEkOQghhIggyUEIIUQESQ6izSosLOS+++6LdRinxev18te//pWLLrqIfv36MX78+BMefy4/VoCioiIKCwtZtGhRrEMRUSLJoZ3ZuHEjhYWFFBYW8vrrrzd7TGFhIbfeeutZjiy+LF68mJdffplJkyYxb948HnjggVMuY9GiRXz44YetEN3pKSoqYtGiRU2WnhXxSybea8cWLVrEtGnTcDgcsQ4l7mzYsIGCggLuvffeFh2/devWiEXs//73v3PllVcyYcKE1gjxlB0+fJi///3v5Obm0q9fvyb7cnNz2bp1KxaLJUbRiWiTK4d2auDAgZSVlfHSSy/FOpQ2IRQK4fV6o1ZeeXk56enpLT7ebrc3u4Rla6mtrY1qeZqmYbfbsVrl+2a8kOTQTk2aNIkBAwawePFiqqqqTnr88erEV6xYQWFhIRs3bgxvW7RoEYWFhezevZu//e1vjBs3jiFDhnDDDTewd+9eAN5//32uvPJKBg8ezPjx43nttdeOe98bNmxg5syZDBkyhLFjx/LXv/41YsEWgJqaGhYsWMAll1zCwIEDueCCC7jrrrs4dOhQszFv2LCBf/zjH0yYMIHBgwfz7rvvnvA5MAyD5557jsmTJzNo0CBGjRrFbbfdxg8//BBRdlFREZs2bQpX4Z2sLv7Y57ex/h5g5cqV4TJ+PvPohg0b+O1vf8uIESMYNGgQU6dO5dVXX40oe/z48cyaNYvvv/+em266ieHDhzNt2jSgIUk88cQTzJgxg1GjRjFw4EAuueQSFi5c2CRZrlixguuvvx6A+++/PxzPrFmzmsT888fZkufs57dfv34906dPZ9CgQYwbN45HH30UwzCaHL9r1y5+//vfc+GFFzJw4EDGjh3LrFmz+Oijj074PIuWkzTfTmmaxt13383s2bN59tlnuf/++6N+H/feey9JSUnceuutuFwulixZws0338zvf/97Fi5cyNVXX8306dN58803+fOf/0x+fj4jRoxoUsb27dtZs2YNM2bM4PLLL2fjxo28/PLL7Nq1iyVLloSrYmpqarj66qspLi5m+vTp9OnTh/Lycl555RVmzJjB8uXLyc3NbVJ244fOzJkzcTqd5OXlnfDx3H333bz77ruMHTuWa665hoqKCpYtW8bVV1/NsmXL6N+/PyNHjuSxxx5j3rx5ZGRkMHfuXOD4U0o3JzMzk8cee4w//OEPjBgxgpkzZ0Yc89prr/HQQw9x3nnnMXfuXBITE9mwYQMPP/wwBw8ejKjOKi4u5oYbbmDixIlceuml1NfXA1BaWsqbb77JpZdeymWXXYbVamXTpk08//zz7Nixg//93/8FYOTIkcydO5dnn32WX//61wwfPhyAjh07nvFzdqyPP/6YV155JfzaWLt2LS+88AJpaWnh57KqqoobbrgBgKuvvpouXbpQVVXFd999x5YtW7jooota/FyLE1CiXfnyyy9VQUGBev7555VSSs2ePVsNHDhQFRUVhY8pKChQt9xyS5PbFRQUqHvvvTeivOXLl6uCggL15Zdfhrc9/fTTqqCgQN16663KNM3w9pdeekkVFBSooUOHquLi4vD2yspKNXDgQHXnnXdG3GdBQYH64IMPmmx/5JFHVEFBgXrnnXeabBs0aJDasWNHk2OLiorU0KFDm8TeGPOll16q6uvrj/9kHeOzzz5TBQUF6vbbb2/ymHbs2KH69eunrrnmmibHX3zxxeq6665rUdmNj/Xnz+/xnvPS0lI1cOBAddddd0Xse+SRR1Tfvn3VwYMHm8RSUFCgXn/99Yjj/X6/CgQCEdufeOIJVVBQoLZs2RLe1vjaWb58ecTxhw4dUgUFBerpp58ObzuV56zx9kOGDFGHDh0KbzdNU02ZMkWNHTs2vO3DDz9UBQUFavXq1RFxiOiRaqV27u677yYYDPLUU09FvexZs2ahaVr4/8argvHjx9O5c+fw9szMTPLy8ti/f39EGXl5eRENsrfccgsAH3zwAQBKKd5++21GjhxJdnY2Lpcr/JOYmMh5553HZ599FlH2NddcQ2JiYoseS+N9zZ07t8lj6tu3LxdffDGbN2/G5XK1qKwztWbNGgKBAFdddVWTx+pyuRg/fjymabJhw4Ymt0lPT+c//uM/IspKSEgIt3UYhoHb7cblcoUXv2lcX/l0nM5z9stf/pKuXbuG/9c0jVGjRlFeXh6uSkxJSQHg008/jXrbiThKqpXauf79+zNlyhTefvttfvvb30Z1kfVu3bo1+T81NRWgyZu/UVpaGocPH47Ynp+fH7EtOzub1NTUcFuCy+Wiurqazz77jNGjRzcby897AgEnrUY6VlFREbquNxtP7969+fDDDykqKiIzM7PFZZ6uxqUwb7zxxuMeU1FR0eT/bt26Hbcn0bJly/jnP//J7t27MU2zyT63233acZ7Oc/bz1wwQbtivrq7G6XRy/vnnc8UVV7BixQrefvttBg4cyJgxY5g8eTK9e/c+7XhFU5IcBHfccQdr1qxh4cKFPP/886d021AodNx9zX0gA1Hv7qiOLGY4ZswY5syZ0+LbnatdeBsf76OPPkp2dnazx/z8Q/Z4V0hLlixh/vz5jBs3juuvv57s7GxsNhulpaXcd9994fs6W0702jg2lkcffZSbbrqJTz75hK+++oolS5bw7LPP8sADD4TXjBZnRpKDoFu3blxzzTUsXbq0Sa+jY6Wnp1NdXR2x/ec9gaKt8VvyscrKyvB4POEPwMzMTFJTU6mtrW21tYC7deuGaZrs2bMn4uqqMcbmrohaQ8+ePQHIyMg448e7atUqcnNzWbx4cZNk/sknn0Qce2zVUEu09nNWUFBAQUEBN998Mx6PhxkzZvD4449z7bXXnnKsIpK0OQgA/vM//5Pk5GQWLFjQ7P6ePXvy7bffNune6Ha7WbFiRavGtW/fvohRwosXLwYIt0Xous7UqVPZunUr7733XrPlVFZWnlEcjff13HPPNfkG++OPP7Ju3TqGDx8e9SqlpKSkZhPypEmTSEhIYNGiRfh8voj9NTU1BAKBFt2HrutomtbkMRmGEX6Ofx4PtLyqqbWes+rq6ojqr9TUVLp27YrX68Xv959ymSKSXDkIoOHb90033XTchulrr72We+65hxtuuIHLL78cj8fDG2+8QZcuXSgvL2+1uAoKCrjnnnuYMWMGPXr0YOPGjaxZs4bzzz+fyZMnh4+78847+frrr7njjjuYNGkSQ4YMwWazUVxczCeffMKAAQOYP3/+accxduxYJk2axOrVq3G73Vx88cXhrrJ2u50HH3wwGg+3ifPOO48vvviC5557ji5duqBpGlOmTKFTp048/PDDPPjgg0yePJlp06aRm5uLy+Xixx9/5MMPP2T16tUt+lY+ceJEHn/8cebMmcMll1xCbW0t77zzTrOD2Xr37o3T6eSVV17B4XCQmppKZmbmcdt5Wus5+9e//sVLL73EhAkT6NGjB1arlX//+9989tlnTJo06ZytLmxrJDmIsNmzZ/PKK680+2E/bdo0ysrKWLZsGfPmzaNbt2787ne/Q9f1M+rRcjIDBgzg/vvv54knnuCf//wnycnJXHfdddx5551NqkFSUlJ49dVXeeGFF3jvvfdYu3YtFouFTp06MXz4cGbMmHHGsSxcuJD+/fuzcuVK5s+fT1JSEiNHjuT2228/pXEMLfXQQw/xl7/8hWeffTbcU2fKlCkATJ8+nZ49e/LCCy/w2muvUVNTQ3p6Onl5edx+++1kZWW16D5uuukmlFK8+eab/O1vfyMrK4tJkyYxffr0JskXGtponnjiCZ588kn++7//m0AgwPnnn3/c5ACt85yNGjWKHTt28NFHH1FeXo6u63Tt2pV7771X2huiSFNnu8VJCCFEmydtDkIIISJIchBCCBFBkoMQQogIkhyEEEJEkOQghBAigiQHIYQQESQ5CCGEiCDJQQghRARJDkIIISJIchBCCBHh/wenBvDvSGLlvQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for plots in reversed(data1):\n",
    "  plt.semilogx(plots[\"x\"],plots[\"trace\"])\n",
    "  if plots[\"name\"] == '$FA$-2':\n",
    "    plt.fill_between(np.array(range(niter+1)), mean_trace2 - 2*std_trace2, mean_trace2 + 2*std_trace2,alpha = 0.3,color='orange')\n",
    "  if plots[\"name\"] == '$FA$-3':\n",
    "    plt.fill_between(np.array(range(niter+1)), mean_trace3 - 2*std_trace3, mean_trace3 + 2*std_trace3,alpha = 0.3,color='b')\n",
    "\n",
    "  print(plots['name'])\n",
    "  print(plots['trace'][-1])\n",
    "  print(plots['reconst'][-1])\n",
    "\n",
    "\n",
    "\n",
    "plt.grid(True)\n",
    "# plt.legend([plots[\"name\"] for plots in data1])\n",
    "# plt.legend([r'$||W_2^{\\rm FA}W_1^{\\rm FA}||_{*}$',r'$||W_2^{\\rm GD}W_1^{\\rm GD}||_{*}$',r'$||W^{\\rm GD}||_{*}$'],fancybox=True, framealpha=0.4)\n",
    "plt.legend(['FA (3l)','FA (2l)','GD (3l)','GD (2l)'],fancybox=True, framealpha=0.4)\n",
    "# plt.legend([r'$||W_1W_2||_*$'],fancybox=True, framealpha=0.4)\n",
    "plt.ylabel(r'Trace Norm')\n",
    "plt.xlabel(r'Number of iterations')\n",
    "plt.savefig(\"trace_norm.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 300
    },
    "id": "86UOqSy-HsjW",
    "outputId": "c2851555-c5e5-4f3b-86e2-93ae2d259ec5"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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lZVFQkICc+fObW5RBF5CKIfrjJ07d5KQkEBCQgJLly6tsU9CQgITJ068wpJdW8yfP58vvviCYcOGMWPGDKZOndrgMebOncv333/fBNI1jqysLObOnetSelZw7SIS713HzJ07l1GjRqHX65tblGuObdu2ER8fz5QpUzzqv3//frci9h9++CF33303gwcPbgoRG0x2djYffvghUVFRdO7c2eVYVFQU+/fvR6VSNZN0Am8jVg7XKUlJSeTm5rJgwYLmFqVFYLPZMBqNXhsvLy+PoKAgj/vrdLoaS1g2FWVlZV4dT5IkdDodarV437xWEMrhOmXYsGF07dqV+fPnU1hYWG//2vbEV6xYQUJCAjt37nS2zZ07l4SEBI4fP86bb75J//79SU1NZcKECfzxxx8ArF+/nrvvvpuUlBQGDRrEV199Veu1t23bxn333Udqair9+vXjjTfecCvYAlBaWso777zDkCFDSEpKok+fPkyePJnMzMwaZd62bRsfffQRgwcPJiUlhe+++67OZ2C1Wpk3bx7Dhw8nOTmZ3r1789RTT3HkyBG3sbOysvjll1+cW3j17cVf/Hyr9u8BVq5c6Rzj0syj27Zt49FHH6VHjx4kJydzxx13sHjxYrexBw0axPjx4zl06BCPPfYY3bt3Z9SoUYBDScyePZsxY8bQu3dvkpKSGDJkCLNmzXJRlitWrODhhx8G4OWXX3bKM378eBeZL71PT57Zpedv2rSJ0aNHk5ycTP/+/XnrrbewWq0u/Y8dO8bTTz/NTTfdRFJSEv369WP8+PFs3ry5zucs8Byh5q9TJEni+eef55FHHuGTTz7h5Zdf9vo1pkyZgq+vLxMnTqSgoIDPPvuMP//5zzz99NPMmjWLBx54gNGjR7Ns2TL+9re/0aFDB3r06OEyxu+//866desYM2YMd955Jzt37uSLL77g2LFjfPbZZ86tmNLSUh544AHOnDnD6NGj6dSpE3l5eSxatIgxY8awfPlyoqKiXMau+tK577778PPzIy4urs77ef755/nuu+/o168fY8eOJT8/n4ULF/LAAw+wcOFCunTpQs+ePXn77beZMWMGwcHBTJo0Cag9pXRNhISE8Pbbb/Piiy/So0cP7rvvPrc+X331FdOmTeOGG25g0qRJ+Pj4sG3bNqZPn87p06fdtrPOnDnDhAkTGDp0KLfddhsVFRUA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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for plots in reversed(data1):\n",
    "    plt.semilogx(plots[\"x\"],plots[\"reconst\"])\n",
    "    if plots[\"name\"] == '$FA$-2':\n",
    "      plt.fill_between(np.array(range(niter+1)), mean_rec2 - 2*std_rec2, mean_rec2 + 2*std_rec2,alpha = 0.3,color='orange')\n",
    "    if plots[\"name\"] == '$FA$-3':\n",
    "      plt.fill_between(np.array(range(niter+1)), mean_rec3 - 2*std_rec3, mean_rec3 + 2*std_rec3,alpha = 0.3,color='b')\n",
    "\n",
    "plt.grid(True)\n",
    "# plt.legend([r'$W_2^{\\rm FA}W_1^{\\rm FA}$',r'$W_2^{\\rm GD}W_1^{\\rm GD}$',r'$W^{\\rm GD}$'],fancybox=True, framealpha=0.4)\n",
    "plt.legend(['FA (3l)','FA (2l)','GD (3l)','GD (2l)'],fancybox=True, framealpha=0.4)\n",
    "# plt.legend([r'$W_1W_2$'],fancybox=True, framealpha=0.4)\n",
    "plt.ylabel(r'Reconstruction error')\n",
    "plt.xlabel(r'Number of iterations')\n",
    "plt.savefig(\"reconstruct.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "DEJ2y2jVHsjX"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "H3vQhqISHsjX"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "name": "Feedback_Alignment.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
