{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from Network_bayesian import Place_net, Grid_net, Coupled_Net\n",
    "import brainpy as bp\n",
    "import brainpy.math as bm\n",
    "from matplotlib.animation import FuncAnimation\n",
    "import time\n",
    "from scipy.stats import ttest_ind, norm\n",
    "\n",
    "# 圆周距离函数\n",
    "def circ_dis(phi_1, phi_2):\n",
    "    dis = phi_1 - phi_2\n",
    "    dis = np.where(dis > np.pi, dis - 2 * np.pi, dis)\n",
    "    dis = np.where(dis < -np.pi, dis + 2 * np.pi, dis)\n",
    "    return dis\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.3333333333333335\n",
      "20\n",
      "[0.62831853 0.4712389  0.37699112]\n",
      "[ 9.54929659 12.73239545 15.91549431]\n",
      "[2.0943951  1.57079633 1.25663706]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# 默认参数\n",
    "# grid spacing\n",
    "lambda_1 = 3\n",
    "lambda_2 = 4\n",
    "lambda_3 = 5\n",
    "Lambda = np.array([lambda_1, lambda_2, lambda_3])\n",
    "L = lambda_1 * lambda_2 * lambda_3\n",
    "# cell number\n",
    "num_p = int(200)\n",
    "rho_p = num_p / L\n",
    "rho_g = rho_p\n",
    "print(rho_g)\n",
    "num_g = int(rho_g * 2 * np.pi)  # 为了让两个网络的rho相等\n",
    "M = len(Lambda)\n",
    "# feature space\n",
    "x = np.linspace(0, L, num_p, endpoint=False)\n",
    "theta = np.linspace(0, 2 * np.pi, num_g, endpoint=False)\n",
    "# connection range\n",
    "a_p = 0.3\n",
    "a_g = a_p / Lambda * 2 * np.pi\n",
    "# connection strength\n",
    "J_p = 20\n",
    "J_g = J_p\n",
    "J_pg = J_p / 25\n",
    "\n",
    "\n",
    "# divisive normalization\n",
    "k_p = 20.\n",
    "k_g = Lambda / 2 / np.pi * k_p\n",
    "# time constants\n",
    "tau_p = 1\n",
    "tau_g = 2 * np.pi * tau_p / Lambda\n",
    "# input_strength\n",
    "alpha_p = 0.05\n",
    "alpha_g = 0.05\n",
    "\n",
    "noise_ratio = 0.007\n",
    "print(num_g)\n",
    "print(a_g)\n",
    "print(k_g)\n",
    "print(tau_g)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "P_CANN = Place_net(z_min=0, z_max=L, num=num_p, a_p=a_p, k=k_p, tau=tau_p, J0=J_p)\n",
    "# Grid cells\n",
    "G_CANNs = bm.NodeList()\n",
    "for i in range(M):\n",
    "    G_CANNs.append(Grid_net(z_min=0, z_max=L, num=num_g, num_hpc=num_p, L=Lambda[i], a_g=a_g[i], k_mec=k_g[i], tau=tau_g[i], J0=J_g, W0=J_pg))\n",
    "\n",
    "Coupled_model = Coupled_Net(HPC_model=P_CANN, MEC_model_list=G_CANNs, num_module=M)\n",
    "\n",
    "def GOP_decoding(z_t, phi_t, Ip, Ig, alpha_p_infer, alpha_g_infer, Ag, Ap, Rp, total_itenoise_rations=5000):\n",
    "    sigma_g = np.sqrt(np.sqrt(np.pi) * Ag ** 3 * rho_g * tau_g / (a_g * alpha_g_infer))\n",
    "    sigma_phi = np.sqrt(8 * np.pi * Ag * tau_g / (Lambda * J_pg * rho_p * Rp))\n",
    "    sigma_p = np.sqrt(np.sqrt(np.pi) * Ap ** 3 * rho_p * tau_p / (a_p * alpha_p_infer))\n",
    "    sigma_g_infer = sigma_g * noise_ratio\n",
    "    sigma_phi_infer = sigma_phi * noise_ratio\n",
    "    sigma_p_infer = sigma_p * noise_ratio\n",
    "    eta = 20. * 1e-6\n",
    "    z_ts = []\n",
    "    phi_ts = []\n",
    "    z_ts.append(z_t)\n",
    "    phi_ts.append(phi_t)\n",
    "    z_encode_space = np.linspace(0, L, num_p, endpoint=False)\n",
    "\n",
    "    for itenoise_ration in range(total_itenoise_rations):\n",
    "        fg_prime = np.zeros((M, num_g))\n",
    "        for i in range(M):\n",
    "            dis_theta = circ_dis(theta, phi_t[i])\n",
    "            fg_prime[i, :] = dis_theta / (2 * a_g[i] ** 2) * np.exp(-dis_theta ** 2 / (4 * a_g[i] ** 2))\n",
    "\n",
    "        dis_z = z_encode_space - z_t\n",
    "        fp_prime = dis_z / (2 * a_p ** 2) * np.exp(-dis_z ** 2 / (4 * a_p ** 2))\n",
    "        \n",
    "        Ig_fgprime_prod = Ig * fg_prime\n",
    "        Ig_fgprime_prod = np.sum(Ig_fgprime_prod, axis=1)\n",
    "        dphi_fr = Ig_fgprime_prod / sigma_g_infer ** 2\n",
    "\n",
    "        Ip_fp_prime_prod = Ip * fp_prime\n",
    "        Ip_fp_prime_prod = np.sum(Ip_fp_prime_prod)\n",
    "        dr_fr = Ip_fp_prime_prod / sigma_p_infer ** 2\n",
    "\n",
    "        phi_z = np.mod(z_t / Lambda, 1) * 2 * np.pi\n",
    "        dis_phi = circ_dis(phi_z, phi_t)\n",
    "        dphi_tr = 1 / sigma_phi_infer ** 2 * dis_phi\n",
    "        dr_tr = np.sum(-2 * np.pi / (Lambda * sigma_phi_infer ** 2) * dis_phi)\n",
    "\n",
    "        dphi = dphi_fr + dphi_tr\n",
    "        phi_t = phi_t + eta * dphi\n",
    "        \n",
    "        phi_t = np.mod(phi_t, 2 * np.pi)\n",
    "        \n",
    "        dr = dr_fr + dr_tr\n",
    "        z_t = z_t + eta * dr\n",
    "\n",
    "        z_ts.append(z_t)\n",
    "        phi_ts.append(phi_t)\n",
    "    return np.array(z_ts), np.array(phi_ts)\n",
    "\n",
    "def Net_decoding(z_truth, phi_truth, Ip, Ig, alpha_p=0.05, alpha_g=0.05, Coupled_model=Coupled_model):\n",
    "    Coupled_model.reset_state()\n",
    "    def initial_net(Ip, Ig): \n",
    "        Coupled_model.initial(alpha_p=1, alpha_g=1, Ip=Ip, Ig=Ig)\n",
    "\n",
    "    def run_net(i, Ip, Ig): \n",
    "        Coupled_model.step_run(i, alpha_p=1, alpha_g=1, Ip=Ip, Ig=Ig)\n",
    "        phi_decode = Coupled_model.phase\n",
    "        z_decode = Coupled_model.HPC_model.center\n",
    "        rp = Coupled_model.HPC_model.r\n",
    "        up = Coupled_model.HPC_model.u\n",
    "        rg = bm.zeros([M, num_g])\n",
    "        ug = bm.zeros([M, num_g])\n",
    "        for mi in range(M):\n",
    "            rg[mi, :] = Coupled_model.MEC_model_list[mi].r\n",
    "            ug[mi, :] = Coupled_model.MEC_model_list[mi].u\n",
    "        return z_decode, phi_decode, rp, up, rg, ug\n",
    "\n",
    "    T_init = 500\n",
    "    z0 = z_truth\n",
    "    phi_0 = phi_truth\n",
    "    fg = np.zeros((M, num_g))\n",
    "    for i in range(M):\n",
    "        dis_theta = circ_dis(theta, phi_0[i])\n",
    "        fg[i, :] = np.exp(-dis_theta ** 2 / (4 * a_g[i] ** 2))\n",
    "    dis_x = x - z0\n",
    "    fp = np.exp(-dis_x ** 2 / (4 * a_p ** 2))\n",
    "    I_place = 1 * np.repeat(fp[np.newaxis, :], T_init, axis=0)\n",
    "    I_grid = 1 * np.repeat(fg[np.newaxis, :, :], T_init, axis=0)\n",
    "    I_place[int(T_init / 3):, :] = 0\n",
    "    I_grid[int(T_init / 3):, :, :] = 0\n",
    "\n",
    "    bm.for_loop(initial_net, (I_place, I_grid), progress_bar=False)\n",
    "    T = 5000\n",
    "    indices = np.arange(T)\n",
    "    I_place = alpha_p * np.repeat(Ip[np.newaxis, :], T, axis=0)\n",
    "    I_grid = alpha_g * np.repeat(Ig[np.newaxis, :, :], T, axis=0)\n",
    "    z_record, phi_record, rp, up, rg, ug = bm.for_loop(run_net, (indices, I_place, I_grid), progress_bar=False)\n",
    "\n",
    "    return z_record, phi_record, up, rp, ug, rg\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.19295613 0.19295613 0.19295613] 0.2009713795376621 [0.22407002 0.16805252 0.13444201]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "Ap = 1.0084058\n",
    "Rp = 0.0128615275\n",
    "Ag = 0.9814125\n",
    "Rg = 0.013212965\n",
    "\n",
    "sigma_g = np.sqrt(np.sqrt(np.pi)*Ag**3*rho_g*tau_g/(a_g*alpha_g)) * 0.01\n",
    "sigma_phi = np.sqrt(8*np.pi*Ag*tau_g/(Lambda*J_pg*rho_p*Rp)) * 0.01\n",
    "sigma_p = np.sqrt(np.sqrt(np.pi)*Ap**3*rho_p*tau_p/(a_p*alpha_p)) * 0.01\n",
    "print(sigma_g, sigma_p, sigma_phi)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Progress: 0.00%\n",
      "Progress: 1.00%\n",
      "Progress: 2.00%\n",
      "Progress: 3.00%\n",
      "Progress: 4.00%\n",
      "Progress: 5.00%\n",
      "Progress: 6.00%\n",
      "Progress: 7.00%\n",
      "Progress: 8.00%\n",
      "Progress: 9.00%\n",
      "Progress: 10.00%\n",
      "Progress: 11.00%\n",
      "Progress: 12.00%\n",
      "Progress: 13.00%\n",
      "Progress: 14.00%\n",
      "Progress: 15.00%\n",
      "Progress: 16.00%\n",
      "Progress: 17.00%\n",
      "Progress: 18.00%\n",
      "Progress: 19.00%\n",
      "Progress: 20.00%\n",
      "Progress: 21.00%\n",
      "Progress: 22.00%\n",
      "Progress: 23.00%\n",
      "Progress: 24.00%\n",
      "Progress: 25.00%\n",
      "Progress: 26.00%\n",
      "Progress: 27.00%\n",
      "Progress: 28.00%\n",
      "Progress: 29.00%\n",
      "Progress: 30.00%\n",
      "Progress: 31.00%\n",
      "Progress: 32.00%\n",
      "Progress: 33.00%\n",
      "Progress: 34.00%\n",
      "Progress: 35.00%\n",
      "Progress: 36.00%\n",
      "Progress: 37.00%\n",
      "Progress: 38.00%\n",
      "Progress: 39.00%\n",
      "Progress: 40.00%\n",
      "Progress: 41.00%\n",
      "Progress: 42.00%\n",
      "Progress: 43.00%\n",
      "Progress: 44.00%\n",
      "Progress: 45.00%\n",
      "Progress: 46.00%\n",
      "Progress: 47.00%\n",
      "Progress: 48.00%\n",
      "Progress: 49.00%\n",
      "Progress: 50.00%\n",
      "Progress: 51.00%\n",
      "Progress: 52.00%\n",
      "Progress: 53.00%\n",
      "Progress: 54.00%\n",
      "Progress: 55.00%\n",
      "Progress: 56.00%\n",
      "Progress: 57.00%\n",
      "Progress: 58.00%\n",
      "Progress: 59.00%\n",
      "Progress: 60.00%\n",
      "Progress: 61.00%\n",
      "Progress: 62.00%\n",
      "Progress: 63.00%\n",
      "Progress: 64.00%\n",
      "Progress: 65.00%\n",
      "Progress: 66.00%\n",
      "Progress: 67.00%\n",
      "Progress: 68.00%\n",
      "Progress: 69.00%\n",
      "Progress: 70.00%\n",
      "Progress: 71.00%\n",
      "Progress: 72.00%\n",
      "Progress: 73.00%\n",
      "Progress: 74.00%\n",
      "Progress: 75.00%\n",
      "Progress: 76.00%\n",
      "Progress: 77.00%\n",
      "Progress: 78.00%\n",
      "Progress: 79.00%\n",
      "Progress: 80.00%\n",
      "Progress: 81.00%\n",
      "Progress: 82.00%\n",
      "Progress: 83.00%\n",
      "Progress: 84.00%\n",
      "Progress: 85.00%\n",
      "Progress: 86.00%\n",
      "Progress: 87.00%\n",
      "Progress: 88.00%\n",
      "Progress: 89.00%\n",
      "Progress: 90.00%\n",
      "Progress: 91.00%\n",
      "Progress: 92.00%\n",
      "Progress: 93.00%\n",
      "Progress: 94.00%\n",
      "Progress: 95.00%\n",
      "Progress: 96.00%\n",
      "Progress: 97.00%\n",
      "Progress: 98.00%\n",
      "Progress: 99.00%\n",
      "Total runtime: 3029.21 seconds\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# 主程序\n",
    "neural_noise_sigma = 0.2\n",
    "noise_level_place = 0.25\n",
    "noise_level_grid = 0.2\n",
    "trial_num = 500\n",
    "z_truth = 30\n",
    "phi_truth = np.mod(z_truth / Lambda, 1) * 2 * np.pi \n",
    "sigma_phi = np.array([31.7,23.8,19])*neural_noise_sigma/25\n",
    "z_decode_gop = np.zeros(trial_num)\n",
    "z_decode_net = np.zeros(trial_num)\n",
    "z_decode_net_motion = np.zeros(trial_num)\n",
    "z_decode_net_visual = np.zeros(trial_num)\n",
    "\n",
    "start_time = time.time()  # 记录开始时间\n",
    "\n",
    "for i in range(trial_num):\n",
    "    z_truth = 30\n",
    "    phi_truth = np.mod(z_truth / Lambda, 1) * 2 * np.pi \n",
    "    z_e = z_truth\n",
    "    psi = phi_truth + sigma_phi * np.random.randn(M)\n",
    "    Ig = np.zeros((M, num_g))\n",
    "    for j in range(M):\n",
    "        dis_theta = circ_dis(theta, psi[j])\n",
    "        Ig[j, :] = np.exp(-dis_theta ** 2 / (4 * a_g[j] ** 2)) + noise_level_grid * np.random.randn(num_g)\n",
    "    dis_x = x - z_e\n",
    "    Ip = np.exp(-dis_x ** 2 / (4 * a_p ** 2)) + noise_level_place * np.random.randn(num_p) \n",
    "    z_decode_n, _, up, rp, ug, rg = Net_decoding(z_truth, phi_truth, Ip, Ig)\n",
    "\n",
    "    max_up = np.max(up, axis=1)\n",
    "    max_rp = np.max(rp, axis=1)\n",
    "    Ap = np.max(max_up[-1])\n",
    "    Rp = np.max(max_rp[-1])\n",
    "    Ag = np.zeros(M,)\n",
    "    Rg = np.zeros(M,)\n",
    "    for mi in range(M):\n",
    "        max_ug = np.max(ug[:, mi, :], axis=1)\n",
    "        max_rg = np.max(rg[:, mi, :], axis=1)\n",
    "        Ag[mi] = np.max(max_ug[-1])\n",
    "        Rg[mi] = np.max(max_rg[-1])\n",
    "    z_decode_g, _ = GOP_decoding(z_t=z_truth, phi_t=phi_truth, Ip=Ip, Ig=Ig, alpha_p_infer=0.05, alpha_g_infer=0.05, Ap=Ap, Rp=Rp, Ag=Ag)\n",
    "\n",
    "    z_decode_mot, _, _, _, _, _ = Net_decoding(z_truth, phi_truth, Ip, Ig, alpha_p=0., alpha_g=0.05)\n",
    "    z_decode_vis, _, _, _, _, _ = Net_decoding(z_truth, phi_truth, Ip, Ig, alpha_p=0.05, alpha_g=0.)\n",
    "\n",
    "    z_decode_net_motion[i] = z_decode_mot[-1]\n",
    "    z_decode_net_visual[i] = z_decode_vis[-1]\n",
    "\n",
    "    z_decode_gop[i] = z_decode_g[-1]\n",
    "    z_decode_net[i] = z_decode_n[-1]\n",
    "    if i % 5 == 0:\n",
    "        print(f\"Progress: {i/trial_num*100:.2f}%\")\n",
    "\n",
    "end_time = time.time()  # 记录结束时间\n",
    "print(f\"Total runtime: {end_time - start_time:.2f} seconds\")\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mean error gop integration: 0.060171200779682875\n",
      "mean error net integration: 0.06064974052026042\n",
      "mean error net motion: 0.0781969332932347\n",
      "mean error net visual: 0.0971042312889722\n",
      "mean error bayesian: 0.060904108761460324\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.06064974052026042\n",
      "[0.2536 0.1904 0.152 ]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "error_int_net = np.abs(z_decode_net-z_truth)\n",
    "error_mot_net = np.abs(z_decode_net_motion-z_truth)\n",
    "error_vis_net = np.abs(z_decode_net_visual-z_truth)\n",
    "error_int_gop = np.abs(z_decode_gop-z_truth)\n",
    "\n",
    "# 保存数据为npz文件\n",
    "np.savez('data/distribution_results.npz', z_decode_net=z_decode_net, z_decode_net_motion=z_decode_net_motion, z_decode_gop=z_decode_gop, z_decode_net_visual=z_decode_net_visual)\n",
    "z_decode_all = np.concatenate([z_decode_net, z_decode_net_motion, z_decode_net_visual, z_decode_gop])\n",
    "min_z = np.min(z_decode_all)\n",
    "max_z = np.max(z_decode_all)\n",
    "# 设置字体\n",
    "plt.rcParams.update({'font.size': 12, 'font.family': 'Arial'})\n",
    "\n",
    "# 画图\n",
    "\n",
    "\n",
    "# 绘制z_decode_gop的直方图及高斯拟合\n",
    "xmin, xmax = min_z, max_z\n",
    "\n",
    "def gaussian_fit(data, xmin, xmax):\n",
    "    mu, std = norm.fit(data)\n",
    "    x = np.linspace(xmin-0.1, xmax+0.1, 100)\n",
    "    p = norm.pdf(x, mu, std)\n",
    "    return x, p\n",
    "\n",
    "x_int_gop, p_int_gop = gaussian_fit(z_decode_gop, xmin, xmax)\n",
    "x_int_net, p_int_net = gaussian_fit(z_decode_net, xmin, xmax)\n",
    "x_mot_net, p_mot_net = gaussian_fit(z_decode_net_motion, xmin, xmax)\n",
    "x_vis_net, p_vis_net = gaussian_fit(z_decode_net_visual, xmin, xmax)\n",
    "\n",
    "\n",
    "# print('mean error gop integration:', np.mean(error_int_gop))\n",
    "# print('mean error net integration:', np.mean(error_int_net))\n",
    "# print('mean error net motion:', np.mean(error_mot_net))\n",
    "# print('mean error net visual:', np.mean(error_vis_net))\n",
    "\n",
    "sigma_1 =np.std(z_decode_net_motion)\n",
    "sigma_2 =np.std(z_decode_net_visual)\n",
    "sigma_3 = np.sqrt(1/(1/sigma_1**2 + 1/sigma_2**2))\n",
    "p_bayesian = np.exp(-(x_int_gop-30)**2/(2*sigma_3**2))\n",
    "\n",
    "print('mean error gop integration:', np.std(z_decode_gop))\n",
    "print('mean error net integration:', np.std(z_decode_net))\n",
    "print('mean error net motion:', np.std(z_decode_net_motion))\n",
    "print('mean error net visual:', np.std(z_decode_net_visual))\n",
    "print('mean error bayesian:', sigma_3)\n",
    "\n",
    "\n",
    "plt.figure(figsize=(4,4))\n",
    "\n",
    "import matplotlib as mpl\n",
    "mpl.rcParams['axes.labelsize'] = 15\n",
    "plt.plot(x_mot_net-30, p_mot_net/np.sum(p_int_net),linewidth=3,label='Mot.',color=[0.,0.5,1])\n",
    "plt.plot(x_vis_net-30, p_vis_net/np.sum(p_int_net),linewidth=3,label='Env.',color=[1,0,0.1])\n",
    "plt.plot(x_int_net-30, p_int_net/np.sum(p_int_net),linewidth=3,label='Both',color=[0,0.5,0.5])\n",
    "plt.plot(x_int_gop-30, p_bayesian/np.sum(p_bayesian),linewidth=3, linestyle='--',label='Bayes',color=[0.2,0.8,1])\n",
    "plt.xlabel('Decoded Position')\n",
    "plt.ylabel('Normalized Density')\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig('figures/normalized_density.pdf')\n",
    "plt.show()\n",
    "\n",
    "print(np.std(z_decode_net))\n",
    "print(sigma_phi)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYAAAAGACAYAAACkx7W/AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAA9hAAAPYQGoP6dpAABo6UlEQVR4nO3deVxUZfs/8M8BGfZdRSUQATcUTBQFNUxB3MAVLVPcMDMrQ9PSn5lZmpmlpuVjLqW4K6i5C7ikJpiJS4q7qIhrCAyLMiz37w+/5zTLmWFmGASG6/16Pa8nznrPIPd1zr1cN8cYYyCEEFLrmFR1AQghhFQNCgCEEFJLUQAghJBaigIAIYTUUhQACCGklqIAQAghtRQFAEIIqaUoABBCSC1Vp6oLUNOUlZXhwYMHsLW1BcdxVV0cQghRwBhDXl4eGjVqBBMTzc/4FAB09ODBA7i5uVV1MQghRKOMjAy89tprGo+hAKAjW1tbAC+/XDs7uyouDSGEKJJKpXBzcxPqKk0oAOiIb/axs7OjAEAIqba0aaKmTmBCCKmlKAAQQkgtRQGAEEJqKQoAhBBSS1EAIISQWooCACGE1FIUAAghpJaiAEAIIbUUBQBCCKmlKAAQQkgtRQGAEEKqoatXr6K4uLhS70EBgBBCqpkLFy4gKCgIQ4YMwYsXLyrtPhQACCGkGrl+/TrCwsKQk5ODp0+forS0tNLuRQGAEEKqiXv37iE0NBRPnjzB66+/jn379sHa2rrS7kcBgBBCqoFHjx4hJCQEGRkZaN68OQ4dOgQHB4dKvScFAEIIqQbeffdd3Lx5E40bN0ZSUhLq169f6fekBWEIIaQaWL58OfLz87Fq1apyl3I0FAoAhBBSRRhjwspdbm5uOHr06Cu9PzUBEUJIFSguLsaQIUOwffv2KisDBQBCCHnFSktLMWrUKMTHx2PMmDF4+vRplZSDAgAhhLxCjDFMnDgRmzdvRp06dbBt2zbUq1evSspCAYAQQl4Rxhg+/fRTrFy5EiYmJti4cSP69OlTZeWhAEAIIa/IvHnz8P333wMAVq5ciaFDh1ZpeSgAEELIK5CYmIhZs2YBABYvXozo6OgqLhENAyWEkFciJCQEkyZNgpOTE2JiYqq6OAAoABBCyCthYmKCJUuWVHUxFFATECGEVJIDBw5g2LBhKCoqAgBwHCdM/KoO6A2AEEIqwR9//IFBgwbhxYsX8Pf3x7Rp06q6SCroDYAQQgzs77//RkREBF68eIHw8PBq0+avjAIAIYQY0OXLl9GzZ0/k5eWhW7du2LZtG8zMzKq6WKIoABBCiIHcunULPXr0wLNnz9ChQwf8/vvvsLS0rOpiqUUBgBBCDKC0tBT9+vXDw4cP4evriwMHDsDW1raqi6URBQBCCDEAU1NTrFixAu3atUNCQgKcnJyqukjlolFAhBBiIG+88QbOnDlTrYZ6akJvAIQQoqeCggJERkbi4sWLwraaUvkD9AZACCF6KSoqwqBBg5CQkIDU1FRcu3at2o72UYfeAAghREclJSV45513kJCQAGtra2zcuLHGVf4ABQBCCNFJWVkZoqOjsWPHDkgkEuzatQtBQUFVXSy9UAAghNQKUqkU6enpkEqlel+DMYZJkyYhNjYWpqam2LZtG0JDQw1YyleL+gAIIUYvNTUVe/fuBWMMHMchPDwc/v7+Ol/nl19+wc8//wyO47Bu3Tr079+/Ekr76tAbACHEqEmlUqHyB14+xe/du1evN4Hhw4eje/fuWL58OYYPH27oor5y9AZACDFqWVlZQuXPY4zh2bNnsLOz0+latra2SEhIgKmpqSGLWGXoDYAQYtScnZ1VxuZzHKf1TN0NGzbgm2++EYKIsVT+AAUAQoiRs7OzQ3h4uBAE+D4AbZ7+d+3ahdGjR2PmzJnYs2dPZRf1laMmIEKI0fP394e3tzeePXsGJycnrSr/xMREvPXWWygtLcXgwYMRHBz8Ckr6atEbACGk1lDuC1Dn1KlTGDBgAGQyGXx8fODj44OlS5ciNTW1kkv4atEbACHE6OkyDPTcuXPo06cPCgsL4e3tjUGDBsHU1FQYPeTt7a1z53F1RW8AhBCjpssw0OzsbPTs2RO5ubkICAjA0KFDUafOf8/J/OghY0EBgBBi1DQNA1Xm6OiIOXPmoH379oiPj4e5ubnCfl1GD9UEFAAIIUZN12Gg77//PpKTk+Hm5qb36KGagvoACCFGjR8GqtwHwFfkWVlZmDx5MhYvXgxnZ2cAEJp99Bk9VJNQACCEGD11FXleXh569+6NM2fO4NGjR0hISFA5187Ozugqfh4FAEKI0ZFKpcjKyoKzs7NQeStX5M+fP0dERATOnDkDZ2dnLFmyROdr1nQUAAghRkWbIZ8ymQxDhgzBH3/8AVtbWxw6dAg+Pj4VumZNRJ3AhBCjoW7IZ2ZmprAWQGlpKaKiorBv3z5YWlpi3759aNeunc7XrMi6AtUFvQEQQoyGuiGfq1evBvByJM/t27exbds2mJmZYceOHXjjjTf0uqY+2USrG3oDIIQYBalUioKCApUhn/IYY7C3t0eTJk2wadMm9OrVq9zrVjSbaHWmdwB48uQJFixYoPBzz549YWlpiVatWmHv3r0GKSAhhJQnNTUVS5YsQXx8vNBOD0A0GDg5OeHAgQOIjIzU6toVySZa3XFM2+xIcm7evInAwEBkZ2fj3r17cHV1xeDBg7Fz507Y2Njg+fPnAIATJ04gMDDQ4IWuSlKpFPb29sjNzTWKfwCE1HRSqRRLlixRaaaJjIyEg4MD1qxZg+TkZDg5OaFZs2bgOA4xMTE6//1KpdIaMR9AlzpKrzeAuXPnIicnB1999RWcnJzw77//Yvfu3WjZsiUePXqEq1evwtbWVuENgRBCKoNYGz0AWFtbw9XVFcXFxTh48CC2bNmCp0+f6v30bmdnBw8Pj2pd+etKr07gw4cPo1+/fpg5cyYAID4+XuhZt7KygpeXFyIjI7Fr1y5DlpUQQlTwbfTyQYBvo9+6dSvmzZsHABg3bhzmzZsHe3v7qipqtaPXG8DTp0/RsmVL4efExERwHIcePXoI25ydnZGfn1/xEhJCjIZUKhWGYxqKujb6EydOYMSIEWCMYcKECVixYoVQ+VdGOWoivd4AGjRogCdPngg/JyYmwtHRUWFixJUrV9CoUaOKl5AQYhS0mUyl72xb5VQPZ8+exeDBg1FSUoJ33nkHP//8sxAgjHVSlz70CgD+/v6Ij4/H8OHDcfLkSTx69AgjR44UvuDNmzdj3759GDFihEELSwipmdRNppJfXKWiFTOf6uHq1avo168fioqK0K9fP6xduxYmJiYayyGRSODu7m5U7fva0CsAzJkzB926dUNISAgYY7CyssJnn30GAJg0aRJ++uknODo6YsaMGQYtLCGkZipvMpWmAMGfL5FIIJPJyn07aNq0Kd566y3cuXMHW7duhZmZWbnliI+Pr5VvA3oFAF9fX6SkpGDFihUAgDFjxgh9Aq1bt8awYcMwe/ZsNGvWzHAlJYTUWJo6aqVSKS5fvixaMZ8+fRrJyckq52mqqE1NTbFq1So8efIEDx8+VAgYYuWQv5+xLflYHr3mAWijqKgI6enpaNGiRWVcvsrQPABC9CPWxANA4clfmbrKWnksf0ZGBpYtW4ZvvvkGhYWFSElJQXJysnCsfMCQL4eYUaNGwcPDo6Ift8roUkfp9QZgamqKL7/8ErNmzVJ7zJw5c7BixQqjWj+TEKI/5Y5aAKITuICXlXZgYKBQiSuTbz568uQJQkNDcf36dWRmZqJ58+YK11R+sufLkZGRgbi4OJX7GkOKB21pFQAuXbqkMOqHMYZbt27hyJEjoscXFxcjKSkJMpnMMKUkhBgF+Zz86enpopV/z549hdTMKSkpagOEk5MTsrOzERYWhuvXr8PNzQ0uLi5qm3fkk7fZ2dmhVatWKCoqUrtSWG2gVQC4ceMGBg8erDDOdv369Vi/fr3acxhj6NOnj2FKSQgxOura40tLS4VKWH4pRx5fUZuYmKBXr164cOECXFxcsHbtWpw4cUL0Xuqe7I19ycfyaBUABg4ciE8//RSPHz8GAKxbtw5t2rTB66+/rnIsx3EwMzODu7s7Jk6caNDCEkKMAz/ev0uXLiqV9uHDh+Hr66vQXPPs2TOYmZmhuLgYTk5OkEgkCA8PR3JyMhwdHZGQkAAPDw+cPHlS9A1A05O9MS/5WB6t+wC+/fZb4b/XrVuHgQMH4osvvqiUQhFCjJdyZ7AyseYa5Qr6rbfewuHDh2FtbY0DBw7Az88PwMuKfs+ePcJxnTp1QseOHWttBV8evTqBy8rKDF0OQkgtIDbeX4z82H0x0dHRSEpKQlxcHDp27Kiwj29W4jjOqNbvrQxaBYDbt2/rfQNPT0+9zyWEGBd1mTuVrVmzRuNY/7CwMFy8eBEymQxSqVTjZDIXFxetJpDVRloFAG9vb42r7KjDcRxKSkp0Po8QYpzUTQjr2rUrjh07JmxTHrrJGMN3332HAQMGoHnz5qJzChwdHctdDrK2zfQtj1YBIDg4WK8AQAgh8vjMnfKVN2NMofLnyfcFzJ8/HzNnzsSiRYtw5swZ0Sf96OhotRPH5I+rTTN9y6NVABD75RBCiD40TcSSxw/d/Omnn4S1Rz777DOUlpaKPukXFxeLBhfl44xhMXdDqdGLwh88eBDt27eHlZUVGjdujPnz52vVvggAZ8+ehZmZGe7cuVO5hSSEqLCzs4OVlZXGY/z8/LBz50589NFHAIAvvvgCU6ZM0bhIu7+/P2JiYjBq1CjhjUDsOPKSXqOAfv31V62PHTt2rD63KNepU6fQr18/vPXWW5g7dy5OnjyJmTNnoqysTHhaUOfChQvo27cv9U8Q8gop5/rXlJgNALZs2YLt27cDAGJiYvDll18CEG9Gkh/nLz9sVNNxRM9kcCYmJuX2CfBfeGlpqd6F06Rnz57Izs7GX3/9JWz77LPPsHz5cjx58gSWlpYq58hkMixbtgyzZs2CpaUlnj17hvT0dJ0SP1EyOEJ0py7Xv7rEbHfu3EFsbCzKysowZMgQrFq1SmUpR/lF2gGoXUimpizmbiiVngzuiy++EA0ABQUFuH79Og4cOIAuXbpgypQp+ly+XEVFRTh27BjmzJmjsD0yMhLfffcdTpw4gbCwMJXz9u/fjzlz5mDmzJlwcXHBu+++WynlI4T8R1Ouf/n+gPj4eOEYFxcXNGrUCPb29mjZsiV+/PFHlRE8/JN+eQvJ1OaZvuXRKwDwr2LqnD59Gm+++Saio6P1uXy5bt++DZlMprLeAL94xPXr10UDQEBAAO7cuQMnJyesXbu2UspGiDHQd2lGMeUtBiOfmI2fxWtpaYmoqCiYmprCxMQEjDHs2bMHNjY2Cn/32qw0RtTTKwCUp2PHjhg0aBB++OEHvPPOOwa/fk5ODgCo/IJtbW0BQO1Cz66urjrfq6ioCEVFRcLPtX0RaWL8ynui1jU4aFoMRl5JSQn+/vtvtG/fHgBgbm6ucq3NmzejTZs2GDBgAIDygwvRrFICAAC4ublh586dlXJtPhWFun4Ifv1PQ5g/f75KUxMhxqq82bQPHz5EUlKSTuv2ltdpC7xMDd2vXz88fvwYJiYmGq954cIFBAQEwNXVVevgQsRVSgAoLi7GgQMH4ODgUBmXF66r/DSel5cHACqdRRUxY8YMhb4MqVQKNzc3g12fkOpE3RP1mjVrRLdr29yiKe3ygwcPEBoaisePH6N+/fparSKYkZEBV1dXrYILUU/vTmAxZWVlyMvLQ2JiIq5du4bx48dXqHDqeHl5wdTUFDdv3lTYzv/MLyZhCObm5qKvooQYI3VDMzXNrpVf2F1T05BYZ+y///6LHj164Pbt2/Dy8sLPP/+M06dPC5V5QECAwkg/XkFBgfDftT2nf0XoFQDmzp2rcfwu8DIN67x58/QumCYWFhYIDg7Gjh07MHXqVKEpKC4uDg4ODujQoUOl3JcQY6f8RF0evrmlvH4DMbm5uejVqxfS0tLg6uqKpKQkeHh4ICgoCBkZGWCMwd3dHfn5+UhLS1M4988//0RAQIDGlNGkfHoFgN9++010O8dxkEgkaNmyJdq0aVOhgpXn888/R2hoKIYOHYqxY8fi1KlTWLhwIRYsWABLS0tIpVKkpaXBy8sL9erVq9SyEGJMlBdhEWv+Af5LrgZA55E4WVlZ6N27N86ePYu6desKlT/w8k1ePpgEBgaqnE8dvYahVwAYNWqUocuhs+7duyM+Ph6zZ8/GgAED4OrqioULF+KTTz4B8HIkQ7du3fDbb79h9OjRVVtYQmogxhhsbW1V2thDQkLg6uoqNLeIre2rqYLm3xYcHBxgYWGBH3/8UWj3F+uETklJUbkGdfQahl4zgdW5d+8eTp06BU9PT6NthqGZwKQmqMg4frHmHE1t7FKpFEuWLFEZiRMTE1Pusfn5+bC1tRWOTU9PR2xsrEqZgoKChAXiKa2zZpU+ExgAVq1ahUWLFuH8+fMwNzfHwYMHMWDAABQXFwN4OSt306ZNMDU11fcWhBA96NMez1M3DDQmJkZtyhRtR+KUlZVh/vz5AF724wGAjY2NwtuCumGdgYGBCAwMpI5eA9MrAGzfvh3vvfceJBIJHj16hMaNGyMmJgYymQxjxoxBeno64uLi0KVLFyGTHyGk8lV0Zqy+E6vKG4mTm5uLmJgYrF27Fq+99hrGjh0rzNfhOA5mZmZIT0+Hs7NzuYneiOHoFQCWL1+OevXqISUlBY0bN8bFixdx/fp1DBo0CGvWrAHw8h/EunXrKAAQ8gppW4GrayLSNLFK+Rzln9WNxElNTcXkyZNx/PhxAMDgwYNhamoqVPB+fn5CRzNf4cfExNDT/iugVwA4f/483nnnHTRp0gTAy7z8HMcJ07OBl520v/zyi0EKSQjRjjYzYzU1EalrzlEemePn54eLFy+KXkM+MADA9OnThcq/T58+cHJyQnR0NIqLi1VGGWnT5EQMR68AUFxcrBCVExMTAbys9HmlpaUwMzOrYPEIIboorz1emyYi5eYcAAodt4wxXLhwQbin/DXkAwUAZGZmCvVDSEgIOnToIKze5eHhofMIImJYegUAT09P4R9AVlYWTp48iZYtW6JRo0YAXv4CExMT0bhxY8OVlBCiFU3t8do2Eck354hV0soYY8jIyFCo/C9duiQs+dilSxe88cYbABTfSCiXT9XSK2ta3759cejQIYwaNQp9+vSBTCYTsn6ePn0affv2xZUrVzB8+HCDFpYQoh07Ozt4eHioPEWLLacIvHxSV0fdOcpu376tUJHXr18fNjY2CAgIQEhICACIduqGh4cL16dcPq+WXvMAXrx4gaFDh2Lv3r0AgODgYBw8eBAWFhaYOnUqFi1ahPDwcGzbtk0Y7mUsaB4AqelOnTolNMvwOI5DdHQ0ZDKZaCevch9Ay5YtVdIziKWHycvLg7W1NUxMTNCzZ0/4+PiI/t3UtlW7KpMudVSFJoJdvnwZjDG0bt1a2Hb69GlIpVKEhoZq9dRQ01AAIDWduslWPHWdvPLNSvfu3UN8fLzKuVZWVrh8+bIwQERely5d4OnpaZBFZoh6rywA1EYUAEhNJzZztzz8zF4A+OOPP5CamqpyzOPHj7Fx40YUFBRg1KhRcHd3V3stXSenGWp1strglcwEBoDDhw9j9erVSE1NRXZ2Np48eYKNGzfi7t27mDJlitE1/xBiDMRGCmnTyXv69GmcOnVKdP+///6L2NhYFBQUwN3dHQ0aNNB4LW0np1VkVjMpn94BYOrUqVi8eLHwD4dv7jl79iyWLFmCxMREHDhwgIIAIdWE/JO0thk/5amr/HNycoTKv2XLlpg7dy7++ecfjdfSZqgnrfdb+fQaBbRp0yYsWrQIwcHB+PPPPzF9+nRh3+TJkxEeHo7jx4/j559/NlhBCSH6S01NxZIlSxAbG4slS5YgNTVVGCnk6uqqMhKnTZs2Cj8HBQWJXjc/Px+xsbGQSqWoW7cuIiIiyq38+WuWN9RT05BVYhh6vQH89NNP8PLywqFDhyCRSJCQkCDsc3Nzw65du+Dr64sNGzYI6ZkJIVVD05M08LKi9fb2Vkm/0L17d4XJYMnJyQrXff78OdavX49nz57B3t4eUVFRsLKyUjhGvnmJ/2+O4xAaGlruUzzNEah8egWAf/75B+PHj4dEIhHdb2Jigt69e2PVqlUVKhwhRD1tO0fVPUmfPn0aycnJatvX+Wvy94iIiMCePXuE/RKJBHXr1sWLFy8watQo0bW4/f390bp1azg5OeGff/4RFpRPSkqChYWFxvZ8Wu+38ukVADiOw4sXLzQewy/QTggxPF06R9Wt88tX/oB4+7rYPcaNG4fVq1cDAExNTTF48GBIpVI4ODioLWdwcDAAICkpSdiubXs+rfdbufTqA/D19cWBAwdQVFQkuj8vLw/79++Hr69vhQpHCFGlrklHKpWKHq8825anqX1d3T2ePn2KM2fOoKysDMDLt311lb/8NTMyMkT3iW0XK7/YrGZScXoFgIkTJ+LOnTvo378/rl69KvxjAF5ODuvXrx8ePHiA8ePHG6yghJCX1DXpZGRkID09XTQQeHt7lzvKR759XewepaWlmDJlCvbt2ydkASgPf83bt29rdTx5tfRqAho+fDj+/PNPrFixAq1atRK229raorCwEIwxjBw5EiNHjjRYQQkhL5/MCwsLRffFx8erbRLKysrSeF359nWpVIqCggKF/fwbQGpqKkxMTODj4yOcJz9rmN8mXw4AOHfunOh93dzctPvgpFLoPQ9g+fLl6NmzJ1auXIm///4b2dnZkEgk6NixI6KjozFs2DBDlpOQWk++TV6Mpvb8Bw8eqL2uj48PevbsCTs7O9F7MMaQkJCA1NRUcByHwYMHw9vbG5GRkXBzcxMdMSTfZq8um2hQUBA161QxvQLA77//jqCgIPTv3x/9+/c3dJkIIUqU2+QBCJUxACHtMo9vErKysoJEIsHhw4fVXjstLQ09e/YUvQcAHD9+XBgCGhERIbz1W1tbK2T1VE4nzdO0zi+pWnoFgPHjx6N9+/bYt2+foctDCBGhrt3f2toaTk5OohWsclDQ5NmzZ2CMqdwjJSUFR48eBQD07NlTaFYSWyaSL6fysFQazll96RUA8vLyaIQPIa+QpklR+uT2UcY33Sifa29vD1NTU7zxxhsKs4G7dOmisvqXfLn4Pgg+QIhNNONRsreqo1c20Lfeegvnz59HSkoKHB0dK6Nc1RZlAyVVRdPYf6lUinv37gkVuFiqZnVCQ0Ph6+uLrKwsPHjwQGG8PvAy0Zu2i8LwOI5DSEgIDh8+rHGuAiV7M7xKzwbap08fHD9+HE2aNEH37t3h6empMgUcePmPYM6cOfrcghCiRN2kKOVKNDQ0VKvr8cdaWFgI6aE5jkNBQQGKi4uF8f1169bVuaz8bF/5n5U7pinZW9XT6w3AxES76QMcx6G0tFTnQlVn9AZAqhOx3P4cx6Fz5844efKkxnP5J3/58+/cuYMNGzbAysoKY8eO1TjJSxN1zVCRkZGwsrKCs7MzsrKyRBemGTVqFDw8PPS6L3kFbwC//fabXgUjhBiWus5hLy8vWFpaCrl3xCrkw4cPw8HBQdiemZmJTZs2oaSkBA0aNICtra1eZeLfLPh7y5Ofq8CvGkjJ3qqOXgFg1KhRhi4HIUREeR2kmjqHPTw80Lp1azx79gz5+fkq/QKMMWFS2ePHj7FhwwbIZDJ4eHhgyJAhMDU11Vi20NBQoY1fXnR0NFxdXWFhYSE6p4D//6SkJNF+AnqzfnUqtCIYIaTyaNNBKjYCKDQ0VJj5y4/Pl0qlooHCysoKWVlZWL9+PZ4/fw5XV1cMGzYMZmZmGsvGcRwsLS3h5+eHCxcuCNvbtGkDV1dXAIp9FgUFBaJzFVxdXdWODiKVjwIAIdVQeR2k6lb3yszMVGj24YOGcqAAXuYHOn/+PGJjY5Gfn4/69etj+PDhMDc3VyjLuHHjkJOTIzTfyJdH+en/4sWL6N69u8oEMXUBiK/0qeKvGhQACKmGNK2GpTz+PjQ0FJ07dwYAxMbGqg0afKDYsWMH7t69ixs3biA/Px8WFhYwNTUVXdAFAIqLi2FlZSVaHmWMMVy+fBmtWrWiyWA1AAUAQqohdW37ZmZmKk/eSUlJ4DgODRs2VBs0+Ir2zJkzuHv3rrDfxsYGo0ePhkwmE+30le+UFSuPWBBISEhAYmKiSpMV5favfvRKB00IqVzKOfz5J2aZTCZa6SYlJaldoY+vwKVSKU6ePAmZTIarV68K+y0tLUVX8wIgPKXb2dnBz89PYZ+fnx8iIiJEJ4ipW6OAcvtXL/QGQEg1pfzEDEDtAiqMMeTk5Gi8XlZWFkpKSrBlyxbcvn0bffv2RUBAgOix7dq1Q3BwsMKkrYsXLyocw7f3x8TE4NChQ0hLS1Mpk/zbB6l+tAoA8gu+6ErbSWOEEFX803d5qaCBl0M5xaSkpCAwMBBSqRRxcXG4ffs2zMzM0KBBA5VjOY5Dly5dUL9+fWRkZAjpnjX1STg5OeHKlSui96Yx/dWbVgGgvCFh6nAch5KSEr3OJYS8pC5Ns7ITJ06Ibk9OTsaff/6JXbt24erVqzA1NcWwYcPg5uaG5s2bw9fXFw4ODiguLhZGEcmLiIiAi4uL6LXNzMxEgwNA+f5rAq0CgJubm0o7X1ZWFvLz8yGRSODj4wNnZ2fk5+fj0qVLKCgowGuvvQYvL69KKTQhtYm6ClZbjDEcOHAAFy9eBMdxGDp0KD799FPh6Z4nlUqxbt06lfP37t2LQYMGiV67uLiY8v3XYFoFgDt37ij8fP78eXTt2hVRUVFYsmSJQkbQwsJCTJ8+HWvWrMHmzZsNWlhCaiOxClYXhw8fxpkzZwAAAwcORPPmzQFAYbKY/M/K+GGb6sbx37x5U2U7DfGsGfRqoJ82bRq8vLzw22+/qaSDtrKywtKlS+Hr64vPPvvMIIUkpDbjRwTpgzEmpHQIDw8XRvLEx8cjNjYWS5YsQWpqKgDg4cOHotfgOA4ODg4KT/Ty6/0qLxDPGIO3t7de5SWvll6jgJKTk/Hee+9p7ODt3LkzVqxYoXfBCDE2+ix8wp/j4uKi11sAx3Ho1q0bmjVrJqRoAFTXD3ZxcVFp++f5+flhzZo1wpuAv78/PDw84O7urrZ5ikb/1Ax6BQBbW1vcunVL4zEXL16kEQCkVpOv8OVn72q78Ik2I3+UtWvXDmfPnsXNmzfh7u4uzA2Qr/yVMcZw79490fu0bt0aFy9eVAgYZ8+exdmzZymjpxHQKwCEhIRg8+bN2LBhA0aMGKGyf+nSpThy5AjGjx9f4QISUhNpqry1WfhEKpViz549Ot+3SZMmSEtLw8aNG+Hm5oYRI0aonSDG4zgO7u7uom8Yly5dUnseZfSs+fQKAF999RUOHjyIUaNG4ccff0THjh1hb2+PnJwcnDx5EpcuXYK7uzu+/PJLAxeXkOpPm2Gb5U2SSklJ0eveCxYswKZNm8AYg5OTE+rU0fwnzj/Fy2QytG3bVugPUD5G3WehjJ41m14BwNPTEydPnsRHH32EI0eO4OzZs8I+U1NTDBw4EEuXLlU7dpgQY6bNsE1NzSRSqVTnAMBxHO7evYstW7agtLQULVu2REREhMZ+uoCAANjb2ytkDxW7rrrFXeQ/B2X0rJn0TgXRokULJCYm4tGjRzh37hxycnKE1LT6rCFKiLFQN2yT31ZeM4mu4/59fHxw+PBhbNy4EcXFxfD29sbgwYPLXdDF29sbW7ZsUWjfly+3fF8Fv7BMZmYmNfcYkQrnAmrQoAF69+6NgoICWFtbG6JMhNRo6lIfa5sJ09nZWaf71alTB+vXr0dRURHc3d0xdOjQcpt+fHx8cOHCBdH0DpGRkbC2tlYoJ/+E7+HhAV9fX2ruMRIVCgBr1qzB6tWrce7cOZSUlKCkpAQ///wzLly4gG+++YbeBEitoG54p/yTNQDRZhL+XIlEAplMBmdnZ+Tl5el0/9zcXDDG0LBhQ7zzzjvldvoCUEncxuM4TmWGsDJq7jEeegUAxhjeeustYYUgS0tLFBcXAwBu3LiB1atX49SpUzh58iQcHBwMWV5CqhWxZRu9vb1VJkeJjfoRGynEj8jRFsdx6NGjB8aOHQsrKytYWFhU6PNQ/p7aRa+ZwD///DPi4uIwbNgwZGZmYtq0acK+uXPn4v3330daWhoWLVpksIISUt2oW7ZRbEw9P+pH/tw9e/aIHie/YIu8sLAw4b8LCwuRmZkJxhgKCgpQr149gzTBduzYscLXIDWHXgFgzZo18PPzw4YNG9CwYUOF0QM2Njb4+eefERAQgPj4eIMVlJDqRl2KZD5vjjzlUT/6DPO8f/8+AODFixfYsGED1q5di/T0dIPk3OI4DhEREfT0X8voFQCuXbuGnj17ajyma9euap9kCKmupFIp0tPTVVayEsOP9pHHt6GLreYlv7iKPgHgypUrKC4uxubNm/HgwQOYmZkZ5Kk/KCgIMTEx5c5MJsZHrz4Ac3NzZGdnazzm6dOnWnVGEVJdiLXna6oUNS10rmn9W33TOxcXF+PQoUO4e/cuzM3NMWLECNSvX1/t8RzHwcPDA+np6WqPGTdunMY0EcS46RUA2rVrh927d+O7774T7eR9/Pgxdu/ejfbt21e0fIS8Eura8zWlawA0L3SubrSMunkCTZs2xY0bN0TvU1ZWhh07diAtLQ116tTBO++8g0aNGmn8TIwxjZV/REQEVf61nF5NQJ988gmePHmCbt264eDBg8LbQFZWFvbt24fu3bsjJycHkyZNMmhhCaksmpY8LE95C50rNyuJLfgeERGBrl27ip5fVlaGPXv2IC0tDSYmJnj77bfRuHFjXT6egsaNG2Py5MnU5EP0ewPo3bs3vv32W/y///f/0LdvX2E7/zrKGMOsWbP0zmFOyKumblWrima1PHXqlEKqhdDQUHTq1En0zUHd03pZWRkKCgrAcRwiIyMVcu337NkTbm5uQrpmbbz55pvU2UsAVGAi2KeffoqwsDCsWrUKf//9N7Kzs2Fra4u2bdsiOjoaQUFBhiwnIZVKU3u+vv7880+FHPuMMSQmJoIxhs6dO6s0EambAVynTh289dZbuHfvHpo0aaKwz83NDTKZDKGhoUhMTNSqXJSqmfA4VpHFRmshqVQKe3t75Obm0lOUEZJKpQZJcyCVSrF48WK1+/v06QNLS0s4OjpCJpNBIpHg5s2bOHbsmHDM3bt3hTTNhhIREUFNP0ZOlzqqwrmACKnJlNM4GCrNwb179zTu379/v8b9Z8+exZ49e9C+fXv07dvXYEFAvvlInxXKiHHRKgDoMjVdHp+itrIcPHgQn3/+OdLS0lCvXj1MmDAB06dP1/jHsmHDBsyfPx+3b9+Gu7s7pk2bhnHjxlVaGUn1peuwT23wY/z1zecPAP/884+wGIy5uXmFyqOMX4OgMj47qXm0CgD8DER1HB0d4eTkhPz8fDx+/BgA4ODgAHt7+4qXUI1Tp06hX79+eOuttzB37lycPHkSM2fORFlZGWbOnCl6zvbt2zFy5Eh8/PHH6NWrF3bt2oV3330XlpaWGD58eKWVlVQ/2g771OUpOTU1Va9VvORdu3YNO3fuBAC0b99eWHJRW/Ipp8VadwsKCpCZmalQTvnPDoDeCmoRvfoA0tPT0aVLF/j4+GDJkiVo1aqVsO/u3buYMmUKTp48iaNHj8LHx8egBeb17NkT2dnZ+Ouvv4Rtn332GZYvX44nT57A0tJS5ZzmzZujTZs22LZtm7DtrbfeEtZQ1Qb1ARiH9PR0xMbGqmwfNWoUPDw8AOj2hiCVSrFkyRK9JnjJl2nDhg0oLS2Fr68vBg4cqHFBF2UtW7ZEr169hD4M+XWItdGpUyckJyfTW0ENp0sdpdc8gKlTp8LGxga7d+9WqPyBl2OMt2zZgnr16mHKlCn6XL5cRUVFOHbsGAYNGqSwPTIyEvn5+Thx4oTKOXfu3MH169dFz7l16xauX79eKWUl1ZO6NA78CBl1bwjqUkToO7uXd//+fWzatAmlpaVo3rw5BgwYoFPlDwBXr14FAGFOgr+/P2JiYhAZGanVWwRf+QPlf15iHPQKAElJSejdu7foUzYAmJmZISwsDH/++WeFCqfO7du3IZPJ0KxZM4Xt/CusWGV+5coVANDpHGK8xCZjyQ/71HVimFhA0UV2djZKSkrQpEkTREZGiq7m1a5dO43XECufnZ0drKysyg1OPj4+ek+EIzWXXqOAJBIJnjx5ovGY9PT0SlshLCcnBwBUXm9sbW0BQPSpRZ9zgJdvG0VFRcLP9ERkPDSlcXj48KHK8RzHwczMDJcvXxZWwOMXT1GeRwAArVu3xqVLl7Qqi6+vL6ytreHq6opGjRrh6dOnKsdYWVmVex2xMf7qUk/If65OnTrhypUrBp8IR6o3vQJAp06dEB8fj2PHjuHNN99U2b9r1y7s3r0bb7/9dkXLJ6qsrAwA1D5xib06qzuH/wev7nV7/vz5mDNnjt5lJdWbulW65Cdw8Vq0aIHVq1erbI+IiIC3tzccHR0RHR2N4uJiODk5Yd++fRrvnZubC47jhPt7enoCgGjlD0C0aVPeG2+8IdrmKxaclNcndnV1NfhEOFL96RUAvvzySyQlJSEsLAwDBgxAhw4dYG9vj5ycHJw4cQL79++Ho6MjvvrqK0OXFwCEBHTKT+P8Unpio4/UnZOfn6/2HACYMWOGQl+GVCqFm5ubXuUmNYO69ny+GVGZ/IgavuJ0cnLS2KyYn5+P2NhYlJWVYeTIkXB0dKxwuV1cXNTuU37bAaDy5qPpjYgYJ70CQNu2bXHgwAG8++67iIuLQ1xcnMIrpr+/P3799Vd4eXkZtLA8Ly8vmJqaqozc4X8WG3nUvHlz4Zi2bdtqdQ7wchy2ocdik+pDbJhneU0mmvCdp4MHD1Z7zPPnz7F+/XpkZWXB3t5e585efSm/7ah7W6CKv/bQeyZwcHAwrl69ir/++gupqanIycmBs7MzAgICFCrYymBhYYHg4GDs2LEDU6dOFZp14uLi4ODggA4dOqic4+3tDU9PT8TFxWHIkCHC9ri4ODRr1qxC2RVJzaRumCffZKLvmH7lZhZ5RUVF2LhxIx4/fgxra2uMHDnSYPNl6M2U6KpCqSA4jkPHjh2rZB3Rzz//HKGhoRg6dCjGjh2LU6dOYeHChViwYAEsLS0hlUqRlpYGLy8v1KtXDwAwa9YsjBkzBs7OzujXrx92796Nbdu2YevWra+8/KRqlTcRzNvbG8HBwTh+/LjO15ZfFUz+HsXFxdiyZQvu378PCwsLjBw5Um0CuPKurZxqQp/lHCkVBKlQAIiLi8Mvv/yCc+fOoaCgAM7OzvDz88Po0aMxdOhQQ5VRVPfu3REfH4/Zs2djwIABcHV1xcKFC/HJJ58AePl0161bN/z2228YPXo0AGD06NEoKirC999/j19//RWenp6IjY2t9LKS6kfTME9dJ1DJ498kACh0Ctva2iI0NBTp6emQSCQYMWKExjZ7dRhjCpV/u3btEBwcrHMFTqkgCFCBbKDvv/8+Vq5cCcYYTE1NUb9+feTm5qKwsBAcx+Hdd9/FihUrDF3eKkczgWs2/qlXIpGI5tAfNmwYtmzZolPlz3Gcwugf5QDSo0cPuLi4IDAwENnZ2RgxYoRKWmd9cRyHmJgYnf4tis1a1uc6pHqq9GygGzduxC+//II2bdrgxx9/ROfOnWFqagrGGE6fPo2PP/4Yq1atQmhoKCIjI/X6EIQYmvJTr5+fHy5evKhQEW7evFnt+eo6hvlhlMDLPz7lvoPExES0bt0aY8aMwePHjw1W+QP/vbXoUnFrevuhAFC76DX84H//+x8aNGiApKQkBAcHC7MWOY5DYGAg9u/fDxcXFyxfvtyghSVEX2Jt/sqVf3mCgoLKne2bkZEh/DdjDI8ePQIAXLp0CdbW1sJYf0PRZ7JWeWkwSO2hVwC4ePEi+vbtq7YDy9nZGX379sX58+crUjZCDEbdU6+2OI6DtbW16DnyOXPk9584cQIrVqxAamqqwnUMRd/JWuWlwSC1h15NQCUlJeWOjZdIJAopFAipSrqM7ec4Dl26dBFm3nIch5CQENHZwcDLSv/s2bNo1qwZnj9/DgBISUnBkSNHAEDh76B3797Izs5GcnKyzp+Br6gNMVmLJn0RQM8A0LJlSxw6dAgvXryAhYWFyv7nz5/j0KFDwuQrQqqa2Jq/YsFAfkRM+/bthQqyvGyfx48fF4aMnjt3DgcPHgQAdO3aVWF97KysLJw+fVqnsr/xxhvw9PRUqKgNUWHTpC+iVwAYNWoUYmJiMGzYMKxYsUJhOFt6ejo+/PBDpKen44cffjBYQQmpKOWn3ps3byp02AYFBaFVq1aQyWSQSqUqFaQ2bxBpaWnYvXs3ACAwMFAlV5aulX+XLl3QvXt3nc4hRFt6DQMtKytDnz59kJCQAFNTUzRt2hT29vbIzMzEgwcPUFZWhpCQEBw8eFA0rW1NRsNAjUd5o4KCgoIQGBgo/J7ljxdz48YNbN68GWVlZWjbti369etXoTb/du3aCXMKlNEkLqJOpQ8DNTExwZ49e7Bo0SKsWbNGWIgCeJlyYezYsZg6darRVf7EeIiNCrpw4YLCMcnJyUhJSRGahOTfIJ4+faqysPvdu3dRVlaGVq1aISIiosIdvsHBwaLbaRIXMRS9ZwKbmZnhs88+w2effYaCggIh2tjY2BiyfIRUCm1X8OJTRLi4uEAmk8HZ2RkeHh7IzMxUOTYkJAT169eHj49PhRK8aRqVo81axvR2QLSldwB4/vw5fvvtNzRv3hwhISHC4i99+vRB79698cEHH7yyLIeE6EqXUUGMMWEdAH5E0OHDhwG8XMnL1tYWderUEZqR9MFxHN5++21IJBJhPH56erpKJV7eJC56OyC60KuGzs3NRXBwMD766CPhDwEACgoKcOjQIcTExKBHjx7CkDhCqhuxsfBt2rQp9zzGGJKSksAYQ3Z2Nn799Vds2rQJMpmsQuVhjGHLli1CLqIlS5YgNjYWS5YsUZhHoGkSl67rGBOiVwCYP38+zp49i4kTJ2LSpEnCdmtra/z777/4+OOPcfToUcybN89gBSWkoqRSKdLT04UK0d/fH9HR0QgLC0N0dDS6d++udbu9VCrFunXrkJeXh7y8PJSUlFS4fHyFvWfPHrWVuKZJXLquY0yIXk1Au3btQrdu3bBs2TKVfY6Ojli0aBHOnDmDTZs2Ye7cuRUuJCHKdG3nFmsaAaCwLTAwUKsmoYKCAmzduhU5OTlwdHTEyJEjtVqv19PTE7dv39Z4jNj9lfP0qJvEJdasRSkeiCZ6BYB79+6hf//+Go8JCgrCjz/+qFehCNFEm3Zu+QABQKVpRDlhG2MMycnJ5fYLvHjxAhs2bMDDhw9Rv359DBs2DLa2thrL26hRI/Tp0we2trZYvHixxmPF7i9WiYtN4hKb7EYpHogmegWAunXrql0flXfr1i168iAGp80omD///FNI28BxHNq2bat13h9Nx8lkMmzatAkPHz6ElZUV5s6diwcPHmi8Xp8+fRAQECD8HBERoXGlsaCgIDg7O+tdiVOKB6ILvQJAWFgY1q5di/3796NPnz4q+5OSkvD777/j7bffrnABCZFX3iiYU6dOKeTsYYwpdKLqqkmTJkhPTwfwchH1x48fw9zcHFFRUeVW/gBUOof5CvratWsq8wgAoGPHjsKKZPpW4pTigWhLr5nAt27dgr+/P54/f45+/fohMDBQmHl2+vRp7N69G+bm5jhz5ozR5QOimcBVS9NiJgBU9lWUcpPMw4cPUVxcDHd3d63PV7fQCg3ZJJWh0mcCe3l54eDBgxgzZgx27NiBHTt2KPyheHp6Yt26dUZX+ZOqp6mdOz093aCVPwCUlpbCy8sLd+7cAWMMDRs21Ol8TQutUHMNqWp6TwQLCgrC1atX8ddff+HcuXPIysqCra0t2rRpgy5dutAkMFJpNI2CMSTGGA4ePIi0tDTs3LkT1tbWSEhI0Pk66vrCaMYuqWoVWhQeADp06IAOHToYoiyEaE3dKJigoCC9cu2LOXLkCP766y8AwJ07dzB06FAkJiYa5C2Dmn9IdVChx/Tr169jxowZ6NmzpxAE9u/fj02bNhn8VZwQbQQGBhpk1a0///xTWBCmb9++CAoKUpmEpS3liVg0Y5dUF3oHgGXLlqF169ZYsGABEhMTcfbsWQDAsWPHEBUVhXfeeQdlZWUGKygh2tC3kpb3999/IzExEQAQGhqKgIAAxMXFITU1Fd7e3ujdu7dO11NuAqIZu6S60CsAHDp0CB9//DGaNm2KjRs34v333xf2DRs2DO3atcO2bdvw22+/GayghGhDKpXC0dER0dHRatMpa3Lx4kXs3bsXwMuVuLp06SLs27NnD5YsWaIyfFNTHqGIiAjY2dkppKGgRdlJdaFXH8DChQvRsGFDnDp1Cvb29rh+/bqwr23btjh69Ch8fHywcuVKREdHG6ywhGii3K4eGhqq0/nyawJ06NBBdCUudaka+IlofLMR8PLtwd/fX7S9n2bskupArwDw999/IyoqCvb29qL7ra2tMWDAAKxfv75ChSNEHeURNGLt6klJSQgNDVW7mLsyPiVzamoqAgICdGpGio+PV9l2+PBheHh4iLb3x8TEICYmhoaAkiqlVwAoLi5GnTqaTy0rK6twilxSu2g7LFLsidrR0VG0Xd3V1RWTJ09GRkYGMjIyRNfk5SfMcBwHMzMzdOzY0SCfhzGG69evq23v9/DwoIqfVCm9AkCLFi2QlJSEsrIy0fH+xcXFSEhIQIsWLSpcQFI7aDssUt0ImujoaNFMmGZmZsjKykJOTo5o5f/o0SOsXbsW/v7+6NGjh0FGEMnf//jx46Lbqb2fVAd6dQKPHj0aly9fxrhx45Cfn6+wLzs7GyNHjsTNmzcRFRVlkEIS46bLsEh1I2iKi4tV8uT7+flhzZo1iI2NFW0G+vfff7F+/Xq8ePEC9+/fh5+fn0IACA0N1bkfQblcYqi9n1QXer0BfPDBB0hMTMTatWuxYcMGYTnI1q1b4+bNm5DJZAgJCcGHH35o0MIS41Regjd56pZydHJygoeHB1xcXHDv3j04Oztjy5YtaivhnJwcxMbGoqCgAA0aNMCwYcNgZmaGQYMGgeM4uLm5CffOzs4WhjlrS11a6cjISLRq1UqnaxFSWfR6AzAxMcGuXbuwePFiNG3aFLm5uWCMIS0tDa+99hrmzZuHAwcOwNTU1NDlJUZIl2GR/Dh/ZZcuXUJqairWrFmDhIQEbN68WW3ln5eXh9jYWEilUtStWxdRUVGwtLREamoq4uPjER8fj5s3bwrHlzec1NfXV2Wb2L35wEJIdaH3RDATExN8/PHHuHz5MvLz83H//n3k5ubi5s2bmDFjRrmdxITwNC1zKMbb21slYCQmJiospahOYWEh1q9fj2fPnsHBwQFRUVHCGyyPb4LKzMwUUkFHRESovWbz5s1FA1hoaKjWn4mQqmCQWtrKykqrJfEIUUeXzJhiTUbaunPnDp4+fQpnZ2cMHz5c7VBmxhhWr14N4L/Ke9y4cVizZo1KR7Obm5vouH5/f3/4+vrSUE9SbWm1HsDIkSP1uzjHYd26dXqdW13RegBVTyqVlru0oibm5uZo3bq1Tu36fF7/mzdvqh2tJJVKqbInVc7g6wFs2LBBZRv/aquurZP/AzG2AEBevYqmTS4tLUVRUZHwllpUVKRzpy7fKa3pTYVW4iI1jVYB4OjRowo/5+fnY/z48eA4DjNmzMAbb7wBZ2dn5OfnIzk5Gd988w1MTEywdevWSik0qT3UTfoS07RpU9y4cUNhW1lZGXbu3InHjx8jKipKbQU9bNgwFBcXIy4uTnS/fKd0eRU95fknNYVWAaBr164KP0+ePBlFRUX4+++/4eHhobCvefPm6NmzJ9q2bYuffvoJq1atMlhhSe0iNj9gz549GDdunOikL+XAwHfmXrp0CSYmJnj69KnaCvnZs2fw8fFRO3xT2w5cyvNPahK9RgFt2bIFAwYMUKn8eQ0bNsTAgQOxc+fOipSN1HLqOnvT0tJURg0xxoTFW4CXlX9CQgJSU1PBcRwGDx4MLy8vtfdycnJCVlYWQkJCFK7bqVMnTJ48WatKnPL8k5pGr1FA+fn55Q7zLCoqQklJiV6FIgRQv8RjcnKykEwtIyNDtNnmjz/+EFYG69evn8bJVw0aNBAmjfHDNxs1aqRzZ64uE9oIqQ70egNo3bo1du7ciQcPHojuv3HjBnbs2IF27dpVqHCkduOXeFQmX6mKvSEkJyfj2LFjAIBevXqhbdu2Gu/z6NEjlSyiyilOtEF5/klNo1cA+OSTT/D06VN06dIFy5cvx99//40bN27gzJkzWLRoEbp27YqCggLMnDnT0OUltUxgYKDKNr5STU1NxY4dOxT2yWQyIelbt27dRM8vD2MM8fHxWLx4MVJTU1X2yy/uIk/XCW2EVDW9moAiIyOxYMECzJo1Cx999JHCPsYYbGxssGbNGtEFNQipKMYY8vLyFNrbeRKJBGPHjsWlS5dE3x50tWfPHmGxF6D8Tl5dJrQRUtX0ngk8bdo0REZGYuvWrTh37hxycnLg7OyMgIAADBs2DA0aNDBkOUktlZWVJbpdOc9+YWEhrKyswHEc+vbta9CKNyMjA61atVI7Kkk+QAA0H4DUHBVKBdGkSRNMnz7dUGUhRMCPpZdIJKJDM+Xz7N+5cwebNm1CREQEfH194enpCXNzcyEFNP+knp2djZMnT+pdJnWjkk6fPo0ePXrofV1CqgplbCPVjnIzi5+fn7BWr7LMzExs2rQJMpkMly5dgq+vr5Aa2tfXFxkZGWCMwd3dHVlZWToHAPkMnppGJXXs2JGe+kmNQwGAVCtizSwXL14UPfbx48fYsGEDZDIZPDw8EBkZqdAer5y3hx/jrzyBrEWLFrhy5YrK9ZU7cflRSfzwUh4N9SQ1FQUA8kpomx5B3Vh6sePWr1+P58+fw9XVVVjQJTU1FefOnUNISAgOHz6sEEgOHz4sLBIvP+ZfbLWwyMhIhUVheIGBgUhJSVEJIjTUk9REFABIpdMlPYLYil/KP+fm5iI2Nhb5+fmoX78+hg8fDnNzc2E/P5ZfGWMMjRo1QkxMjDBKR127vrW1tWig4od6Kn8eevonNREFAFKppFIp9uzZI/zMp0dQHjnDE6tglfsAzp07h9zcXDRo0ADDhw9XuxaFWCDhh2bK31vdcerQUE9iLHQOALdu3cK///6L1157Da6urpVRJmJEMjIyVLYxxoShlWLkK1gzMzOsWbNGYf+bb76JDh06oLi4GLa2tmrv3aVLF5w8eVLjk7q+T/Q01JMYA60DwLFjxzBx4kRcu3ZN2BYYGIgVK1aIrolKCCDefq8NvoJNT08HYwwymQympqbCOtMDBgxAQkKC2vMbN24sVP4AEBISorbZiZ7oSW2lVSqICxcuoHfv3rh69SoaNmyIgIAAODk5ITk5GV27dhXWTSVEmbu7u+h2bRdHd3Z2RklJCbZs2YLt27ejpKQEHMfB3d1dJe+OvLt37yoEn8OHD2vMymlnZwcPDw+q/EmtolUA+O6771BcXIxff/0V9+/fR0pKCp48eYL58+cjJycHixYtquxyklqqpKQER44cwe3bt3Hr1i1kZWUhPDwcrq6uCouul4dvdiKE/EerAHDy5EkMGDAAo0ePFrZxHIfPPvsMnTt3xpEjRyqrfKSGU5fK4dmzZ+We+/fff6Nbt244deoUTE1N8cUXX+Dbb7+Fv78/UlNTheGcyrp06SJ6vfj4eCQkJFB+fkL+j1YB4MmTJ2jevLnovo4dO+LevXsGLRQxHuWlSJbPrCn/37m5uZg4cSIuXrwIjuMwdOhQlJaW4vjx48jMzBRNBNeuXTv06NFD7WxfxhiSk5PVZvkkpLbRqhNYJpMpjLOWZ2tri8LCQoMWihgPTaNs5OcHyOM4DhcvXsSZM2cAAIMGDRIeQM6ePat2QffU1FStO501DUUlpLbQKgDoO5KDEODlKBsXFxfcu3cPzs7OMDMzU/sUD7xsHtq9ezeAl2vxajvKTJd/p5S+gRCaCEZeAXVP+uo4OjoiKioKDx48QPv27SulTJS+gRAdVgTTdrQFIcrt+tpW/jKZTPhvd3d3jBkzRud7h4aGKvzM5/uRXxyG0jcQ8hLHtPjLNDExgYODAxwcHFT25eTkIDc3F40bN1a9OMfh1q1bBilodSGVSmFvb4/c3NxaXYGoS+6mnPcnMDBQJXumPD4Nw5UrV7Bv3z4MHz4cDRs2FPZFR0cjJycHt2/fFjpuNV131KhRcHJyEoZ8yid0k0qlNNmLGD1d6iitm4BycnKQk5Ojdv+dO3dUtlXmW8OiRYvw888/IzMzEy1atMCcOXPQv39/rc9funQpFi1aJFpuopm65G5iqZxTUlLUXoev4I8cOYJ58+ahuLgY586dEwIAYwz37t1Dq1at0KpVK3Tt2lWowAGozcppZ2cnmmaC0jcQokirAFDdZvouXLgQM2bMwOzZs9G+fXusWbMGgwcPxpEjRxAcHFzu+Rs3bsQnn3xCuYz0IFbJ8yNq1KVyDgoKEq2sw8PDcefOHUyYMAHFxcXw8fFBz549Fc5PSEhAYmKiEGTs7OyEtw/5lM/UrEOI7rQKAGLNO1Xl+fPn+OabbzBlyhTMmjULANCrVy906tQJX331lWgaYN6TJ0/w+eefY9WqVdQBqCd1lfyzZ89EUzkDL1Mrx8TEICMjQ1i7183NDbdu3UKfPn1QWFiIXr164csvv8ShQ4dEr88HGeVFXkJDQ9GoUSNq1iFED3qPArp79y5u376Np0+fom7dumjSpAmaNGliyLKJOn36NHJycjBo0CBhG8dxGDRoEGbMmIHnz5/D0tJS9NxvvvkGCQkJiI+Px+7du3Hs2LFKL68xkG/vV5evn6+AQ0NDkZiYqHD+4cOHhf/nK+5WrVphwoQJkEql6NSpE3744Qe89tpraNmyJS5fvqyS6I1P5aD89pGUlISYmBiq/AnRg84BYN26dVi2bBnOnTunsu/111/HxIkTER0dbZDCieGX7mvWrJnCdm9vb5SWluLWrVto3bq16LkTJkzAwoULYWZmJowzJ5opD+Fs166dyqpa8k0vfPu9POUFWhhjmD17Nv7991+0bNkSXbt2xfbt24VrtWrVComJiSpBhj9X+do0np8Q/WgdAIqKijB06FChMnBzc4OPjw+cnZ2Rl5eHy5cv49y5cxg/fjx27dqFrVu3ql2oQ52CggLs3LlT7X4XFxehI1r5D57PC68pz0uLFi10Kg/w8nMXFRUJP9emPDJiQzj5WbihoaFwdXVVaXrRZkUvAOjfvz9at26Nxo0bC7PMGWPYs2cPxo0bJzp72M3NTefFWwgh6mkdAN5//33s2bMHHTt2xOLFixEYGKhyzPnz5zF58mTs27cPH3zwAX777TedCvP06VNERUWp3d+1a1f06NFDdB9fKZiYaD21QSvz58/HnDlzDHrN6khsWKe65RKBl805Yk0vYqkf+DeG4uJi1Knz8p+cubk5Pv/8c8THx6tce82aNQgPD1dYupG/Dy3HSIjhaBUATp06hbVr16J3797Ys2eP2kr29ddfx5EjRzB48GDExsZi3Lhx6Ny5s9aF8fDwKHfC0M8//wwAyMvLg6Ojo7A9Pz8fAGBvb6/1/bQxY8YMTJkyRfhZKpVqncu+plA3rFNdpy6guelFbIGVkpISDBs2DM2bN0fXrl0RHh4u5PRX1+kbExMDDw+Pcq9NCNGPVo/LK1asgIWFBdatW1fuEzbHcVi1ahVsbGxUlvIzBD4p2M2bNxW237x5E+bm5vD09DTo/czNzYXx48Y4jlzdsE6pVCp06oopr+lFfoGVwsJCzJo1Cw8ePMCFCxcwfPhwYUhneHi46Pl8gCnv2oQQ/WkVAM6cOYM+ffqgbt26Wl3U2dkZvXr1wqlTpypUODGdOnWCtbU14uLihG2MMezYsQNdu3ZVm7WUiNM0rBN4+X2LpVdQbnqRT/8gTyaTITIyEsePH4ednR0SExPh7e0t7Pf398e4ceM0powmhFQOrZqA7t27p9MsWwDw8vLCvn379CqUJlZWVpg6dSq++uorSCQSdOrUCb/++ivOnj2Lo0ePCsfdv38f9+/fR9u2bSkoaKBpWCevc+fO8PX1FU2vAKhvQiotLcWIESNw4MABWFpaYt++fSrr8kqlUshkMo0jiwghlUOrAGBubo7nz5/rdOHCwkJhZI6hzZ49G3Xq1MHKlSvx/fffw8fHB7t371bob1i9ejXmzJmD9PR0lXZk8h9N+fqVjxNLr6CuCcnT0xNTpkzB9u3bIZFIsGvXLpWVupQDR0hIiOjIIkJI5dAqGVzHjh0hk8lEx/6r065dO1haWqpdnammMtZkcPomSktPT0dsbKzK9mbNmuGdd96BiYkJtm/fjkGDBimMNAKAJUuWqLx50KQuQirG4Mng+vTpg6+++gr79u1D3759yz1+z549OH/+PC0WX4Po28Gtrgmpb9++WLlyJSQSCQYNGiSaJZQmdRFStbR6A8jOzoanpyckEgn27t2LgIAAtceeOHEC/fr1g4WFBa5du2Z0f8zG+gYgT12qZ3XHyOfnKSsrQ+fOnREYGKiQhnnx4sXl3pfeAAipOIO/ATg6OmLjxo3o378/unTpgsjISPTt2xctW7aEvb09CgsLcfXqVcTHxyMuLg4cx2H37t30h1wDiXXo8pk++YAgdkxMTAy++OILbNu2Dc+fP0dKSorQGcx3Hitr2rQpbty4IfwcEhJC/2YIeYW0egPgHT16FCNHjkRmZqZorn/GGLy9vREbGys6U9gYGPMbgFQqVWmXB/5L5cB31PJJ3eT3161bFx9++CEYYwgLC0OnTp2EJ/p79+6JzvhVJj+CiBCin0pZEAYAunXrhtu3b2Pr1q1ITEzElStXkJubCycnJ3h5eWHQoEEIDw+HRCKp0AcgVUNd6gfl7JvKrl69im3btoExhvbt2wvLL/Jt+u7u7lrdXz7ts7EFV0KqI52zgZqZmWHEiBEYMWJEZZSHVCFNqR/kyR+Tnp6O7du3o7S0FH5+fujTp4/wdiifJjoiIgJ79uwptwzUEUzIq2PYzGmkRtOUmoHHJ3fjOA7379/H5s2bUVJSgv79+2PlypUwNTUVjpOfT+Dv74/JkycjMjKy3KVCzczMDPOBCCEa6fQGIJPJsHnzZnh6euKNN94AACxevFhlhIepqSn27t0rOnGIVG/e3t5q3wLk2+h9fHwQGBgImUyGkJAQbNmyBRYWFmjZsqXa+QT8ZLKioiKVNNPyiouLK+WzEUIUaR0A0tLSMHDgQNy8eRNRUVFCAJBKpbh//77K8R9++KFCagZSM6jrB+jZsyd8fHyESt3BwQEHDhzAzJkzsXLlSlhYWAD4b52GrKwshZ/l8Rk9MzIyFHI6AZQDiJBXSasAkJ+fj7CwMDx8+BDjxo3DpEmTFPZzHIfS0lIAQFlZGUJCQnD8+HGcPn0aHTt2NHypic60GdsPqJ/YxVf+paWlMDU1FZK+rVixAjY2NsKx6vICKRN7G6AcQIS8WloFgP/973948OABfvzxR3z00UcajzUxMcGiRYvQrl07bNq0iQJANaBtpQyoX9AlKysLT548weDBgzFmzBhIpVKV66nLC6RpVA/l9yek6mgVAHbv3g0vL69yK39e27Zt0aZNGxw/frxChSMVV9FKOTMzE0lJSSgsLMTatWvx+PFjfP3115g4cSLq1KmjcD1NqaU1VezGuM4CITWBVqOArl69qnYpRnU6deqEu3fv6lUoYjjl5ftXx87ODk5OTjh8+DBevHiBjRs34vHjx7CxscHw4cOFpR3lr8c3H8mjNn1Cqi+t3gDy8vKEDI7KwsPD0aBBA5Xt9vb2ePHiRcVKRypMm3z/6mRlZUEmk2HLli24f/8+LCwsEBUVhbp164peT9vU0oSQ6kGrAODi4oKnT5+K7mvXrh3atWunsv3Bgwdo2LBhxUpHKqwilbKdnR3i4uKQnp4OiUSCESNGoEGDBhoXb6E2fUJqDq0CgJeXF/744w+tL8qnDHj99df1LRcxIH0r5W3btuHatWuoU6cOhg0bBjc3N6HDt3Xr1hrH+1PFT0j1p1UAGDx4MCZNmoSdO3di4MCB5R6/du1aPHz4EPPnz69wAYlh6FMpjx8/HpcvX0bXrl0REBCgUNlTJU9Izaf1egAtW7ZEUVERduzYgW7duqk99tChQxgyZAjq16+Pf/75B5aWlgYtcFUz5mygwMu3N8YYTEwMnyVE27kIhBD9Vcp6AOvXr0efPn0QGhqK3r17Y+DAgfDz84OTkxOePXuG69evY/v27di7dy/q1KmDjRs3Gl3lXxt88803SEtLw9q1aw2ak0eXuQiEkFdDp/UATp8+jaioKNy8eVPtegCenp7YunWraMewMTDmN4Bly5YJs7x37tyJAQMGGOS6YusM0OpfhFSOSlsPoGPHjrhy5QoSEhIQHx+PGzdu4PHjx3B2doanpycGDx6Mvn37UjbHGmjt2rVC5T979myDVf6A5rkIFAAIqTo6rwdgamqK3r17o3fv3pVRHlIF4uPjER0dDQCIiYnB7NmzDXr9isxFIIRUHloPoJY7ePAghg0bhrKyMkRHR2PRokXl5uvXFT8XQX6hGJogRkjV06kPgFTvPgBdR9lIpVJ4eHggOzsbQ4cOxaZNm4QFXSqrfDRBjJDKVWl9AKT60meUjZ2dHbZv346VK1di/fr1lVr58/ejip+Q6oOagIyAuoyffM5+ZfIvfSEhIdi6dSskEskrKSshpPqgAGAEdMn4efv2bQQGBuLq1auvqniEkGqKAoAR0DYNc2ZmJkJDQ/HXX39h4sSJr7KIhJBqiAKAEdBmlM3Tp0/Ro0cPpKenw8vLCxs3bqyq4hJCqgnqBDYSmjJ+5ubmolevXrhy5Qpee+01JCUlUapuQggFAGMiNsqmsLAQ4eHhSE1NRb169ZCUlAQPD4+qKSAhpFqhJiAjN3PmTJw8eRL29vZISEhA8+bNq7pIhJBqggKAkZs9ezbCwsKwf/9+WqCHEKKAmoCMED8ZDAAcHBxw6NChKi4RIaQ6ojcAI8MYQ0xMDBYtWlTVRSGEVHP0BmBkZs2ahaVLl4LjOISGhsLPz6+qi0QIqaboDcCIfPfdd5g3bx4A4KeffqLKnxCiEQUAI7FixQp89tlnAIBvv/2WZvoSQspFAcAIbNq0SajwZ8yYIQQCQgjRhAJADXf9+nWMHDkSjDF88MEHQhMQIYSUhzqBa7hmzZph4cKFuHDhgtD5Swgh2qAAYAQmT56sMPafEEK0QU1ANdD58+cRHh6OnJwcYRtV/oQQXVEAqGGuXbuGsLAw7Nu3D9OnT6/q4hBCajAKADXI3bt3ERoaiqdPn6Jt27ZYsGBBVReJEFKDUQCoIR49eoTQ0FDcv38fLVq0wKFDh2Bvb1/VxSKE1GAUAGqAZ8+eoUePHrh58yY8PDyQlJSEevXqVXWxCCE1HAWAGmDkyJG4dOkSGjZsiKSkJLi6ulZ1kQghRoACQA2wcOFCtGnTBomJifDy8qrq4hBCjATNA6gBWrZsidTUVJiYULwmhBgO1SjVUGlpKcaNG4ekpCRhG1X+hBBDo1qlmmGMYcKECVizZg0GDhyIrKysqi4SIcRIUQCoRhhjmDp1KlavXg0TExP8+uuvcHZ2rupiEUKMFAWAauTrr78WlnJcvXo1hgwZUsUlIoQYMwoA1cSSJUswe/Zs4b/HjBlTxSUihBg7CgDVQEJCAiZPngwA+Oqrr/Dxxx9XcYkIIbUBDQOtBrp164bhw4ejYcOG+Pzzz6u6OISQWoICQDVgZmaG2NhYcBxHaZ0JIa8MNQFVkT/++AOTJk1CaWkpgJfj/KnyJ4S8SvQGUAX++usvhIeHIz8/H56enoiJianqIhFCaiF6A3jFLl26hF69eiE/Px/du3fHhAkTqrpIhJBaigLAK3Tz5k306NED2dnZ6NixI37//XdYWFhUdbEIIbUUBYBX5P79+wgNDcWjR4/g5+eH/fv3w8bGpqqLRQipxSgAvAIlJSXo3bs37t69i6ZNmyIhIQFOTk5VXSxCSC1HAeAVqFOnDubNm4emTZsiKSkJLi4uVV0kQggBxxhjVV2ImkQqlcLe3h65ubmws7PT6dzi4mKYmZlVUskIIUS3OoreAF4hqvwJIdUJBQBCCKmlKAAQQkgtRQGAEEJqKQoAhBBSS1EAIISQWooCACGE1FIUAAghpJaiAEAIIbUUBQBCCKmlKAAQQkgtRQGAEEJqKVoSUkd87jypVFrFJSGEEFV83aRNnk8KADrKy8sDALi5uVVxSQghRL28vDzY29trPIbSQeuorKwMDx48gK2tLTiOq+ri1EhSqRRubm7IyMjQOaW2MaLv4z/0XVQcYwx5eXlo1KgRTEw0t/LTG4COTExM8Nprr1V1MYyCnZ0d/ZHLoe/jP/RdVEx5T/486gQmhJBaigIAIYTUUhQAyCtnbm6O2bNnw9zcvKqLUi3Q9/Ef+i5eLeoEJoSQWoreAAghpJaiAEAIIbUUBQDySixatAheXl6wsLDA66+/jt9//12n85cuXQoPD4/KKVwlO3jwINq3bw8rKys0btwY8+fPL3eW5oYNG9CqVStYWlqiefPmWL169SsqbeXS57vgnT17FmZmZrhz507lFrI2YYRUsu+++46Zmpqyr776iu3fv58NHjyYmZqasj/++EOr8zds2MDq1KnDGjduXLkFrQR//vknMzMzYyNGjGAHDhxgM2fOZBzHsblz56o9Z9u2bYzjOBYTE8MOHjzIJkyYwACwDRs2vMKSG54+3wXv/PnzzMXFhQFg6enplV/YWoICAKlUhYWFzMHBgU2bNk3YVlZWxgIDA1lISIjGcx8/fszeffddBoA5OTnVyAAQFhbGAgICFLZ9+umnzMbGhhUWFoqe06xZMzZkyBCFbUOHDmVeXl6VVs5XQZ/voqioiH3//ffM0tKSOTk5UQAwMGoCIpXq9OnTyMnJwaBBg4RtHMdh0KBBOHbsGJ4/f6723G+++QYJCQmIj49HRETEqyiuQRUVFeHYsWMKnx0AIiMjkZ+fjxMnTqicc+fOHVy/fl30nFu3buH69euVWubKos93AQD79+/HnDlzMHPmTCxYsOBVFLVWoQBAKtWVK1cAAM2aNVPY7u3tjdLSUty6dUvtuRMmTMCNGzdUKo2a4vbt25DJZKKfHYBoZa7p+1J3Tk2gz3cBAAEBAbhz5w5mzpyJOnUoc42h0TdK9FZQUICdO3eq3e/i4oKcnBwAUMnrYmtrC0BzWu0WLVpUvJBVSJ/PXpHvqzrT93O5urpWarlqOwoARG9Pnz5FVFSU2v1du3ZFjx49RPex/xv5UV62wpqsrKwMANRmjRX77OrOqenflz7fBal89K0TvXl4eIC9HEgg+r9jx47BwcEBwH/rKPDy8/MBaJ+1sCbiP7vy0y3/XYh9dnXn1PTvS5/vglQ+CgCkUjVv3hwAcPPmTYXtN2/ehLm5OTw9PauiWK+El5cXTE1NRT87APj4+Kico+n7UndOTaDPd0EqHwUAUqk6deoEa2trxMXFCdsYY9ixYwe6du1q1Em/LCwsEBwcjB07dihMdoqLi4ODgwM6dOigco63tzc8PT0Vvi/+nGbNmqFx48aVXu7KoM93QSof9QGQSmVlZYWpU6fiq6++gkQiQadOnfDrr7/i7NmzOHr0qHDc/fv3cf/+fbRt29aogsLnn3+O0NBQDB06FGPHjsWpU6ewcOFCLFiwAJaWlpBKpUhLS4OXlxfq1asHAJg1axbGjBkDZ2dn9OvXD7t378a2bduwdevWKv40FaPPd0EqWdVMPyC1SVlZGfv666+Zm5sbs7CwYP7+/uzAgQMKx8yePVvjJJ9Ro0bVyIlgjDG2Y8cO5uvryyQSCWvSpAn7/vvvhX1Hjx5lANhvv/2mcM6KFSuYt7c3Mzc3Zy1btmSxsbGvuNSVQ5/vgvfbb7/RRDADo3TQhBBSS1EfACGE1FIUAAghpJaiAEAIIbUUBQBCCKmlKAAQQkgtRQGAEEJqKQoAhBBSS1EAIISQWooCQA23du1acByHRo0aITs7W+1xX375JTiOw9q1ayt0vx07duDixYsVukZlGD16NDiOQ1JSksGvzX93NWlh9mPHjoHjOIwYMcLg175z5w44jkOXLl0Mfu2qwHEcXnvtNYVtMpkMCxYsQGlpaRWV6tWgAGAkHj58iEmTJlXqPaZPn47BgwfjyZMnlXofQqpacHAwpk+fDmNPlEABwIhs2LABu3fvrrTrP3r0qNKuTUh1Ulv+rVMAMBLt2rUDALz33nt49uxZFZeGEFITUAAwEr169UJUVBQePXqkU1NQaWkpli1bBn9/f1hZWcHe3h4hISE4ePCgwnEcx2HdunUAgB49eoDjOCxfvhwcx+G7775TOPby5cvgOA62trYoKSlR2Dd06FBwHIf79+8L2/bt24cePXrA3t4eFhYWaNWqFb7++msUFhYqnMu38//555/o0KEDzM3N0aRJE9y7d0/0sz179gxt2rQRLaOYkpISfPvtt2jRogUsLS3RrFkz/PTTT2qPf/bsGaZNmwYvLy+Ym5vDxcUFw4YNw9WrV0WPP3LkCMLDw1GvXj3Y2tqibdu2WLFihUo787NnzzB16lR4eXlBIpGgbt266N+/P1JSUkSvGxcXh6CgINjY2KBBgwaIiYkRVhBTpu3vW77MISEhsLe3h5OTE0aPHo2nT5+q/U6Ulfc7e/78OebOnYtWrVrBwsICTk5OiIiIwOnTp1WudffuXYwcOVL4vhs0aIDIyEicPXtW9J5i/UFvvvkmOI5TWZiGx/ed3L17FwBgZmaGN998U9i/c+dOvPnmm6hfvz4sLS3RokULzJgxA7m5uVp/J9VKFWcjJRXEp8idOXMme/bsGWvYsCEDwH7//XeF4/h0y/KpdktKSlhERAQDwHx8fNikSZPYxIkTWYMGDRgAtmTJEoXz27RpwwCwqKgoNnv2bHbv3j0GgIWGhirca8mSJQwAA8BOnTolbC8uLmYODg7M399f2Pbll18yAMze3p6NGDGCffTRR6xVq1YMAGvXrh2TSqXCsaNGjWIAmIuLC3vzzTfZ1KlT2ZAhQxT2JSYmMsYYy8nJYe3atWMA2A8//FDu91hWVsb69u3LALAWLVqwjz/+mA0aNIiZmJgI3+mqVauE4x88eMA8PT0ZANatWzc2bdo0NmLECGZubs5sbGzYyZMnFa6/bNkyxnEcs7GxYe+88w6bMmUKa968OQPAJkyYIBx379495u7uzgCwjh07ssmTJ7MhQ4YwiUTCTE1NVdJCf/fddwwAq1u3Lnv33XfZmDFjmKOjo1Dm4cOH6/X7ZoyxzZs3M1NTU2Ztbc2ioqLYhAkTWKNGjYRrd+7cudzvVdPvLD8/nwUEBDAALCAggE2ZMoVFR0cze3t7VqdOHRYXFydc5+nTp6xJkybMwsKCDR8+nM2YMYMNGzaMSSQSZmFhwS5cuKByT/7fgryuXbsyAOzGjRvCNgDM1dWVMcZYeno6mz17NrO3t2cA2KxZs4S/mW3btjGO45inpyebNGkSmzZtGuvYsaPwXZSVlZX7fVQ3FABqOPkAwBhju3fvZgBYgwYNWFZWlnCcWADgK+qRI0ey4uJiYfuzZ89Yy5YtmampKbty5YqwXewP6/XXX2cWFhassLBQ2BYeHs5sbW0ZADZv3jxh+7FjxxgANmfOHMYYYykpKQwA8/LyUsjxXlxcLNzr/fffV7l/586dWWlpqcL3IF+2vLw8FhQUJFqpqbNhwwYGgPXq1Ys9f/5c2L5v3z5mYmKiEgAGDBjAALCVK1cqXOfcuXPMwsKCNW7cWPhO09PTmbm5OWvUqJFCxfP8+XMhSP3zzz+MMcZ69erFALCvv/5a4bpnz55lNjY2zNzcnN27d48xxtitW7eYRCJh7u7uwjZ+e6NGjVQCgC6/79zcXObk5MTs7OzYxYsXhWOfPHnCfH19dQ4AYr+zmJgYhX+7vLt377L69eszW1tb4d/wsmXLGAC2evVqhWPXr1/PALDx48er3FOfAMBr3LgxA6DwPbVr145ZW1uz3NxcYVtZWRkLDQ1VedipKSgA1HDKAYAxxkaMGKHyxy8WAHx8fJipqanCP2jexo0bGQD26aefCtvE/rBmzZrFALBDhw4xxl5W3ra2tmz8+PHMwcGBhYSECMdOmzaNAWDnz59njDH27rvvMgBsy5YtKvfPzs5mDg4OzNLSkr148ULh/osXL1Y5nt/3+++/s+DgYMZxHPvpp5/K+/oEPXv2ZAAUKjve4MGDFQLAo0ePGMdxLCAgQPRa/Ofav38/Y4yxb7/9Vm0w+uOPP9icOXNYWloay8zMFN5AxPBvS1999RVjjLH58+czAGzp0qUqx/IVpvy/AV1+35s3b2YA2JQpU1SO3bNnj84BQPl3VlJSwuzs7FiDBg1YSUmJynnz5s1jANjy5csZY4wtXbqUAWDjxo1jMplMOE4mk7Hbt28rVNSVFQD8/f2ZiYkJS0pKUjj2yZMn7MmTJ+V+F9URLQlphJYuXYrDhw9j48aNGDJkCPr3769yTEFBAdLS0mBnZ4dFixap7OeHeqampmq8V0REBL7++mskJiYiLCwMKSkpyMvLQ2hoKDIyMnDs2DHIZDJIJBLs27cPjRs3Rps2bRSu3bVrV5XrOjg4wM/PD8ePH8e1a9fg5+cn7NO0kPzEiRORmZkJCwsL9OzZU2PZ5aWmpsLa2hqtW7dW2ffGG28gPj5e+Pns2bNgjKGoqAhffvmlyvF8/0Zqaip69+6Nc+fOAQCCgoJUjg0ODkZwcDAAYO/evQDEvw/+WADC9fjvr2PHjqJllqfr71uXa2tD+Xd27do1SKVSODg44Ouvv1Y5/vr16wrlGDJkCL7++musXr0a8fHxCAkJQVhYGHr16oUmTZroXB59fPDBB4iOjkZoaChatGiBsLAwhIWFoXv37rC0tHwlZTA0CgBGyNHREb/88gv69euHCRMmiP7B5uTkAACkUinmzJmj9lrljShq3749GjZsiISEBCxcuBBJSUngOA7dunXD3bt3ceDAAaSkpMDd3R1paWkKHdR8x5m9vb3otV1dXQG8rLzkWVlZqS1PZmYmBg4ciJ07dyI6Olro1CtPTk4OnJ2dRY91dnZW+JmfcHfx4kWNk+L47y4rKwuA+s/J0/X74H+HYscrl1nX37ema9vb26NOHd2qDuXfGf8d3rt3T6vyNGjQAGfPnsX8+fOxc+dOxMXFIS4uDgDQvXt3/O9//0OzZs10KpOuxo4dCxcXFyxbtgxHjx7F0qVLsXTpUtjY2GDChAmYP3++zt9LVaNRQEYqIiICI0aMUDsqyNbWFgDQsmVLsJdNgaL/Ux5hoYzjOPTt2xf//PMPHj9+jMOHD8PX1xd169ZFSEgIAODo0aPYt28fACi8jdjZ2QF4WWmL4SsJ5cpMk2+++QY7duxASEgIjh8/juXLl2t1nrOzM6RSqejEH+URNfx39/7772v87n744QeF48VGipSUlKCoqAiA7t8H//98Za1NmbX9fWu69osXL1RGd+mKL0/v3r01lkf+zcvNzQ3Lly/HgwcPcPHiRSxevBgBAQE4cuQIIiIihN8dH8TLyspU7qv8MKGrvn374uDBg8jOzkZCQgKmTJkCCwsLfP/991iwYEGFrl0VKAAYsaVLl6JBgwbYuHGjUAHz7Ozs4OnpiZs3bwpPqPJSU1Mxbdo0oVkCgNonaf6Pb/fu3fjrr7/QvXt3AMDrr78OZ2dnIQA4ODgIzRgA4O/vDwA4fvy4yjVfvHiBlJQU2NraonHjxlp/5oCAAADAL7/8AktLS0yfPl0Y0lfeeYWFhaIBT3n45euvvw4A+Ouvv0SvtWXLFsyaNUt4O+CbvMSGNu7duxeWlpaYP38+2rZtCwBITk4WrWCPHj0KAPD19VX4rCdOnCi3zLr+vnW5tj6aN28OS0tLnD9/HjKZTGV/YmIiZsyYIdx/69ateP/995GbmwuO4+Dr64uYmBgkJyejadOmuH79Oh4+fAgAkEgkAIC8vDyFa5aVleHWrVtalU/537pUKsXXX38tNJ9ZWVmhR48e+OGHH4Qg9ccff+jwDVQTld/NQCqTWCewvN9//10YkgmlTmC+o23o0KGsqKhI2C4/PG/9+vXCduXOTV5BQQGztLRkTZo0YQDY7t27hX2RkZHM3NxcGL4n79SpUwwAc3d3VxkFNH78eJ1Gd4jt4ztfe/Tooebb+w8/eio4OFhh6OnJkyeZubm5yiigHj16iHbsXr16lTk6OjJTU1PhM924cYOZmpoyd3d3dufOHeHYFy9esMDAQMZxHEtNTWWMMRYWFsYAsC+++ELhuufPn2dOTk7M3Nyc3b59mzH2ciiqjY0Nc3FxYdeuXROOffDgAfP29lbpBNbl911YWMhcXV2ZpaUlS05OFo7Nzc1lnTp10rkTWOx3xv97mjJlisIIoUePHgn/lk6cOMEYY2zGjBkMAJs7d67CNf7991/m7OzMbG1thc+0ePFiBoCNGjVK4dgffvhB+DsorxO4adOmDIAwuq20tJS5uroya2trhe+asf/+Bt97771yv4/qhgJADVdeAGCMseHDh4sGAJlMxkJCQhgA1rRpU/bBBx+wjz76iLm5uTEAbMiQIQojNL7++msGgLVv355Nnz5dYegnP4ZeeZTJ//73P+He27ZtUynbF198wfB/8wCioqLYpEmTWOvWrRkA5u/vr3AtXQNAcXGxMHdBefigmLFjxzIAzMPDg3344Yfs7bffZmZmZkJlIB8A7ty5I3xPXbp0YZ988gkbPXo0s7GxYQDYjz/+qHDtRYsWMQDMwcGBjRo1isXExAiVtPzvTv66gYGBbPLkyWzo0KHM3Nyc1alTR+H3xxhja9euZSYmJszOzo6NHj2avffee6x+/fpCmeUDgK6/74SEBGZhYcEkEgkbNmwY+/DDD5mHh4dQ7ooGgJycHGFI6euvv84+/vhj9t5777G6deuqjEB6/PixMDInJCSETZs2jU2cOFGYk7Bs2TLh2H///ZfZ2dkJw3o/++wzFhoayszNzYXhweUFAP57Gjx4sBDkt2zZIszlGDVqFJs+fTqLjIxkderUYfXq1RMCc01CAaCG0yYAZGVlCZN9lCsQmUzGFi1axNq2bcssLS2Zvb09a9++Pfvll18UhsDx1+ndu7dw3OXLl4V9K1asYABYhw4dFM65fv06A8AkEonCk7W8Xbt2sW7dujFbW1tmZWXF/Pz82LfffisM/+TpGgAYY+zMmTPM1NSU2dvbs/v376v9jhh7Oab7559/Zr6+vszCwoK5u7uzefPmsTVr1qgEAMZeDv+bPHky8/T0ZBKJhLm4uLCwsDCWkJAgev39+/ez7t27Mzs7OyaRSFibNm1UrslfNyYmhjVp0oSZmZkxFxcXNmTIEHb69GnR6yYmJrI333yT2draMkdHRzZmzBiWmpqqEgAY0+33zX9/4eHhzNHRkdna2rJBgwYJEwArGgAYYywvL4/Nnj2btWzZkpmbmzNnZ2f2xhtvsK1bt6ocm5GRwT744APWtGlTZmlpKQwzln/j5F24cIH17duX2draMhsbGxYaGspSUlLYJ598olUA+Pvvv5mfnx+TSCTMy8tL2J6QkMB69uzJGjVqxCQSCXvttdfYuHHj2N27d8v9LqojjjEjT3dHCCFEFHUCE0JILUUBgBBCaikKAIQQUktRACCEkFqKAgAhhNRSFAAIIaSWogBACCG1FAUAQgippSgAEEJILUUBgBBCaikKAIQQUktRACCEkFqKAgAhhNRS/x/V3BSdSmwusQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# 设置字体\n",
    "plt.rcParams.update({'font.size': 12, 'font.family': 'Arial'})\n",
    "mpl.rcParams['axes.labelsize'] = 15\n",
    "# 画图\n",
    "plt.figure(figsize=(4, 4))\n",
    "z_decode_all = np.concatenate([z_decode_gop, z_decode_net])\n",
    "min_z = -0.2\n",
    "max_z = 0.2\n",
    "\n",
    "plt.plot(z_decode_net-30, z_decode_gop-30, '.', color='gray')\n",
    "plt.plot([min_z, max_z], [min_z, max_z], 'k--')\n",
    "plt.xticks([-0.1,0.,0.1])\n",
    "plt.yticks([-0.1,0.,0.1])\n",
    "plt.xlabel('Network decoded results')\n",
    "plt.ylabel('GOP decoded results')\n",
    "plt.xlim([-0.22,0.22])\n",
    "plt.ylim([-0.22,0.22])\n",
    "plt.tight_layout()\n",
    "plt.savefig('net_gop_comparison.pdf')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
