{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import math\n",
    "import torch\n",
    "import brainpy as bp\n",
    "import brainpy.math as bm\n",
    "import matplotlib.pyplot as plt\n",
    "import argparse\n",
    "import os,sys\n",
    "import time\n",
    "\n",
    "from utils import metric\n",
    "from utils.logger import Logger\n",
    "from utils.helperFunctions import circ_dis\n",
    "from utils.params import params_prob, params_LSC, params_PSC\n",
    "from utils.generation import LSC, PSC\n",
    "from utils.Network import Place_net, Grid_net, Coupled_Net\n",
    "from utils.ProbModel import position2phase_modules, position2phase_modules_batch\n",
    "from utils.ProbModel import position2phase_loglikelihood_modules_batch_MAP, PSC_fr_loglikelihood_modules_batch_MAP, LSC_fr_loglikelihood_batch_MAP, prior_function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "device = torch.device('cpu')\n",
    "\n",
    "### GOP decoding\n",
    "def PSC_GOP_decoder(PSCModel,total_iterations, z_t, phi_t, activation_gs):  \n",
    "    '''\n",
    "    GOP: Gradient based Optimization of Posterior\n",
    "    activation_gs shape [M, n_g]\n",
    "    '''\n",
    "    z_ts = []\n",
    "    phi_ts = []\n",
    "    z_ts.append(z_t.detach().cpu().clone())\n",
    "    phi_ts.append(phi_t.detach().cpu().clone())\n",
    "    for iteration in range(total_iterations):\n",
    "        ## compute the log likelihood\n",
    "        # partial ln P(rg|phi) / partial phi\n",
    "        fg_prime = PSCModel.forward_modules_prime(phi_t) # shape [M, n_g]\n",
    "        Ig_fgprime_prod = activation_gs * fg_prime # shape [M, n_g]\n",
    "        Ig_fgprime_prod = torch.sum(Ig_fgprime_prod, dim=1) # shape [M]\n",
    "\n",
    "        dphi_fr = Ig_fgprime_prod /  params_PSC['sigma_g']**2 \n",
    "        dphi_fr = dphi_fr.to(device)\n",
    "        \n",
    "        ## transition model\n",
    "        phi_z = position2phase_modules(z_t, params_PSC)\n",
    "        dis_phi = circ_dis(phi_z, phi_t) # shape [M]\n",
    "        # partial ln P(phi|z) / partial phi\n",
    "        dphi_tr = 1 / params_PSC['sigma_phi']**2 * dis_phi # shape [M]\n",
    "        dphi_tr = dphi_tr.to(device)\n",
    "        # partial ln P(phi|z) / partial z\n",
    "        dr_tr = torch.sum(-params_PSC['Lphase'] / (params_PSC['lambda_gs'] * params_PSC['sigma_phi']**2) * dis_phi, dim=0) # shape [1]\n",
    "        dr_tr = dr_tr.to(device)\n",
    "\n",
    "        ## update\n",
    "        dphi = dphi_fr + dphi_tr\n",
    "        phi_t = phi_t + params_prob['eta'] * dphi\n",
    "        # boundary condition\n",
    "        phi_t = phi_t % params_PSC['Lphase']\n",
    "        z_t = z_t + params_prob['eta'] * dr_tr\n",
    "\n",
    "        ## record\n",
    "        if iteration % 100 == 0 or iteration == total_iterations - 1:\n",
    "            z_ts.append(z_t.detach().cpu().clone())\n",
    "            phi_ts.append(phi_t.detach().cpu().clone())\n",
    "    return z_ts, phi_ts\n",
    "\n",
    "### MAP decoding\n",
    "def read_MAP_indices_max_vec(log_posterior):\n",
    "    '''\n",
    "    log_posterior shape [n_pos, n_phi, M]\n",
    "    Note: we can compress log_posterior from [n_pos, n_phi, n_phi, ..., n_phi] to [n_pos, n_phi, M] \n",
    "            because different modules are independent, covariance matrix is diagonal, \n",
    "            non-diagonal combinations are abandoned.\n",
    "    '''\n",
    "    n_pos, n_phi, M = log_posterior.shape\n",
    "    # Calculate the maximum probability values and their indices for each [n_phi, M] matrix\n",
    "    max_prob_values = np.max(log_posterior, axis=1)\n",
    "    max_prob_indices = np.argmax(log_posterior, axis=1)\n",
    "    # Sum the maximum probability values across the M modules for each position\n",
    "    max_prob_sums = np.sum(max_prob_values, axis=1)\n",
    "    # Find the position with the highest sum of maximum probabilities\n",
    "    z_est_index = np.argmax(max_prob_sums)\n",
    "    max_log_posterior = max_prob_sums[z_est_index]\n",
    "    phi_est_index = max_prob_indices[z_est_index]\n",
    "    return z_est_index, phi_est_index\n",
    "\n",
    "def PSC_MAP_decoder(PSCModel, activation_gs, n_pos=1000, n_phi=100):  \n",
    "    '''\n",
    "    MAP: Maximum A Posteriori\n",
    "    activation_gs shape [M, n_g]\n",
    "    '''\n",
    "    L_env = params_prob['L']\n",
    "    ## parameter space\n",
    "    # z_candidates = LSCModel.mu_p\n",
    "    # phi_candidates = PSCModel.mu_g # the density for different modules is the same\n",
    "    phi_candidates = torch.linspace(-np.pi, np.pi, 100)\n",
    "    z_candidates = torch.linspace(0, L_env, 1000)\n",
    "    ### Q: candidate number is not necessarily equal with the neuron number?\n",
    "\n",
    "    phi_candidates_modules = phi_candidates[:,None].expand(-1,params_PSC['M']) # shape [n_phi, M]\n",
    "    phi_z_candidates = position2phase_modules_batch(z_candidates, params_PSC) # shape [n_pos, M]\n",
    "    ## transition likelihood\n",
    "    log_likelihood_tr = position2phase_loglikelihood_modules_batch_MAP(phi_candidates_modules, phi_z_candidates) # shape [n_pos, n_phi, M]\n",
    "    log_likelihood_tr = log_likelihood_tr.to(device) ### Q: prior correlation p(z, \\phi)?\n",
    "    ## firing rate likelihood\n",
    "    fg_modules = PSCModel.forward_modules_batch(phi_candidates_modules) # shape [n_phi, M, n_g]\n",
    "    log_likelihood_fr = PSC_fr_loglikelihood_modules_batch_MAP(activation_gs, fg_modules) # shape [n_phi, M]\n",
    "    log_likelihood_fr = log_likelihood_fr.to(device) \n",
    "    ## posterior\n",
    "    log_posterior = log_likelihood_tr + log_likelihood_fr # shape [n_pos, n_phi, M]\n",
    "    # to numpy\n",
    "    log_posterior = log_posterior.detach().cpu().clone().numpy()\n",
    "    ## MAP estimation\n",
    "    z_est_index, phi_est_index = read_MAP_indices_max_vec(log_posterior)\n",
    "    phi_est_index = np.array(phi_est_index)\n",
    "    z_est = z_candidates[z_est_index]\n",
    "    phi_est = phi_candidates[phi_est_index]\n",
    "    z_est = z_est.detach().cpu().clone().numpy()\n",
    "    phi_est = phi_est.detach().cpu().clone().numpy()\n",
    "    return z_est, phi_est\n",
    "\n",
    "\n",
    "\n",
    "def Simplified_PSC_MAP_decoder(PSCModel, activation_gs, n_pos=1000, n_phi=100):  \n",
    "    '''\n",
    "    MAP: Maximum A Posteriori\n",
    "    activation_gs shape [M, n_g]\n",
    "    '''\n",
    "    L_env = params_prob['L']\n",
    "    ## parameter space\n",
    "    # z_candidates = LSCModel.mu_p\n",
    "    # phi_candidates = PSCModel.mu_g # the density for different modules is the same\n",
    "    phi_candidates = torch.linspace(-np.pi, np.pi, 100)\n",
    "    z_candidates = torch.linspace(0, L_env, 4000)\n",
    "    # first step: decode phi\n",
    "    phi_candidates_modules = phi_candidates[:,None].expand(-1,params_PSC['M']) # shape [n_phi, M]\n",
    "    fg_modules = PSCModel.forward_modules_batch(phi_candidates_modules) # shape [n_phi, M, n_g]\n",
    "    log_likelihood_fr = PSC_fr_loglikelihood_modules_batch_MAP(activation_gs, fg_modules) # shape [n_phi, M]\n",
    "    log_likelihood_fr = log_likelihood_fr.to(device) \n",
    "    phi_decode_index = torch.argmax(log_likelihood_fr, axis=0)\n",
    "    phi_decode = phi_candidates[phi_decode_index]\n",
    "    # print(phi_decode)\n",
    "\n",
    "    # Second step: decode z\n",
    "    prior = prior_function(phi_decode, z_candidates)\n",
    "    # plt.plot(prior)\n",
    "    z_est_index = torch.argmax(prior)\n",
    "    z_decode = z_candidates[z_est_index]\n",
    "\n",
    "    z_est = z_decode.detach().cpu().clone().numpy()\n",
    "    phi_est = phi_decode.detach().cpu().clone().numpy()\n",
    "    return z_est, phi_est\n",
    "\n",
    "\n",
    "def LSC_MAP_decoder(LSCModel, activation_p):  \n",
    "    '''\n",
    "    MAP: Maximum A Posteriori\n",
    "    '''\n",
    "    L_env = params_prob['L']\n",
    "    ## parameter space\n",
    "    z_candidates = torch.linspace(0, L_env, 4000)\n",
    "\n",
    "    # fp = LSCModel.forward_modules_batch(z_candidates) # shape [n_phi, M, n_g]\n",
    "\n",
    "    # LSC_fr_loglikelihood_batch_MAP\n",
    "    # # MAP estimation\n",
    "    # max_index = torch.argmax(activation_p)\n",
    "\n",
    "    # z_est = z_candidates[max_index]\n",
    "    # z_est = z_est.detach().cpu().clone().numpy()\n",
    "    # return z_est\n",
    "\n",
    "    # firing rate likelihood\n",
    "    fp = LSCModel.forward_batch(z_candidates) # shape [n_pos, n_p]\n",
    "    log_likelihood_fr = LSC_fr_loglikelihood_batch_MAP(activation_p, fp) # shape [n_pos]\n",
    "    log_posterior = log_likelihood_fr.to(device)\n",
    "\n",
    "    # to numpy\n",
    "    log_posterior = log_posterior.detach().cpu().clone().numpy()\n",
    "    posterior = np.exp(log_posterior)\n",
    "    # plt.plot(log_posterior)\n",
    "    # plt.plot(posterior)\n",
    "    ## MAP estimation\n",
    "    z_est_index = np.argmax(posterior)\n",
    "    z_est = z_candidates[z_est_index]\n",
    "    z_est = z_est.detach().cpu().clone().numpy()\n",
    "    return z_est\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "sigma_g: [0.32746834 0.32746834 0.32746834]\n",
      "sigma_phi: [0.23239731 0.17429799 0.13943839]\n",
      "sigma_p: 0.18045679564717002\n",
      "30.052513\n",
      "30.08252\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# torch.manual_seed(1)\n",
    "exp_type = 'cth'\n",
    "save_path = os.path.join('./results/',  exp_type)\n",
    "os.makedirs(save_path, exist_ok=True)\n",
    "\n",
    "### initialize LSC and PSC\n",
    "LSCModel = LSC(params_LSC).to(device)\n",
    "PSCModel = PSC(params_PSC).to(device)\n",
    "\n",
    "### stimulus and ground truth position\n",
    "pos_gt = torch.tensor(30., dtype=torch.float32)  # ground truth position\n",
    "pos_gt = pos_gt.to(device)\n",
    "phi_gt = position2phase_modules(pos_gt, params_PSC)\n",
    "\n",
    "pos_gt_np = pos_gt.detach().cpu().clone().numpy()\n",
    "phi_gt_np = phi_gt.detach().cpu().clone().numpy()\n",
    "\n",
    "total_iterations = 5000\n",
    "n_methods = 3\n",
    "rate_ampl = 2.\n",
    "pg_ratio = 0.0874/0.00716\n",
    "phi_ampl = 5.0\n",
    "activation_p = LSCModel.forward(pos_gt, noiseFlag=True,  rate_ampl=rate_ampl*pg_ratio)\n",
    "activation_gs = PSCModel.forward(pos_gt, noiseFlag=True, rate_ampl=rate_ampl, phi_ampl=phi_ampl)\n",
    "g_noise = np.array(PSCModel.sigma_g*rate_ampl)\n",
    "p_noise = np.array(LSCModel.sigma_p*rate_ampl*pg_ratio)\n",
    "phi_noise = np.array(PSCModel.sigma_phi*phi_ampl)\n",
    "print('sigma_g:', g_noise)\n",
    "print('sigma_phi:', phi_noise)\n",
    "print('sigma_p:', p_noise)\n",
    "plt.figure()\n",
    "plt.plot(activation_p)\n",
    "### PSC GOP decoding\n",
    "# z_t = pos_gt # previous position\n",
    "# phi_t = position2phase_modules(z_t, params_PSC)\n",
    "# z_ts, phi_ts = PSC_GOP_decoder(PSCModel, total_iterations, z_t, phi_t, activation_gs)\n",
    "# z_ts = torch.stack(z_ts).detach().cpu().numpy() # shape [total_iterations+1, 1]\n",
    "# phi_ts = torch.stack(phi_ts).detach().cpu().numpy() # shape [total_iterations+1, M]\n",
    "# plt.plot(z_ts)\n",
    "\n",
    "# plt.figure()\n",
    "### PSC MAP decoding\n",
    "z_est_MAP, phi_est_MAP = Simplified_PSC_MAP_decoder(PSCModel, activation_gs)\n",
    "z_place_MAP = LSC_MAP_decoder(LSCModel, activation_p)\n",
    "print(z_est_MAP)\n",
    "print(z_place_MAP)\n",
    "# print(z_ts[-1])\n",
    "# print(phi_ts[-1])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Simulation Loop for Rate Amplitude 0.0: 100%|██████████| 1000/1000 [00:49<00:00, 20.12it/s]\n",
      "Simulation Loop for Rate Amplitude 0.7142857142857143: 100%|██████████| 1000/1000 [00:42<00:00, 23.58it/s]\n",
      "Simulation Loop for Rate Amplitude 1.4285714285714286: 100%|██████████| 1000/1000 [00:41<00:00, 24.25it/s]\n",
      "Simulation Loop for Rate Amplitude 2.142857142857143:  80%|████████  | 800/1000 [00:41<00:10, 19.31it/s]\n",
      "Rate Amplitude Loop:  20%|██        | 3/15 [02:54<11:39, 58.27s/it]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[4], line 69\u001b[0m\n\u001b[1;32m     67\u001b[0m z_t \u001b[38;5;241m=\u001b[39m pos_gt \u001b[38;5;66;03m# previous position\u001b[39;00m\n\u001b[1;32m     68\u001b[0m phi_t \u001b[38;5;241m=\u001b[39m position2phase_modules(z_t, params_PSC)\n\u001b[0;32m---> 69\u001b[0m z_ts, phi_ts \u001b[38;5;241m=\u001b[39m \u001b[43mPSC_GOP_decoder\u001b[49m\u001b[43m(\u001b[49m\u001b[43mPSCModel\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtotal_iterations\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mz_t\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mphi_t\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mactivation_gs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     70\u001b[0m z_gop \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39marray(z_ts)\n\u001b[1;32m     71\u001b[0m z_decode_psc_gop[i\u001b[38;5;241m/\u001b[39m\u001b[38;5;241m/\u001b[39m\u001b[38;5;241m50\u001b[39m] \u001b[38;5;241m=\u001b[39m z_gop[\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m]\n",
      "Cell \u001b[0;32mIn[2], line 25\u001b[0m, in \u001b[0;36mPSC_GOP_decoder\u001b[0;34m(PSCModel, total_iterations, z_t, phi_t, activation_gs)\u001b[0m\n\u001b[1;32m     22\u001b[0m dphi_fr \u001b[38;5;241m=\u001b[39m dphi_fr\u001b[38;5;241m.\u001b[39mto(device)\n\u001b[1;32m     24\u001b[0m \u001b[38;5;66;03m## transition model\u001b[39;00m\n\u001b[0;32m---> 25\u001b[0m phi_z \u001b[38;5;241m=\u001b[39m \u001b[43mposition2phase_modules\u001b[49m\u001b[43m(\u001b[49m\u001b[43mz_t\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mparams_PSC\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     26\u001b[0m dis_phi \u001b[38;5;241m=\u001b[39m circ_dis(phi_z, phi_t) \u001b[38;5;66;03m# shape [M]\u001b[39;00m\n\u001b[1;32m     27\u001b[0m \u001b[38;5;66;03m# partial ln P(phi|z) / partial phi\u001b[39;00m\n",
      "File \u001b[0;32m~/Desktop/Complementary_Coding_of_Space/tianhao-dev/Non-local_error/utils/ProbModel.py:117\u001b[0m, in \u001b[0;36mposition2phase_modules\u001b[0;34m(x, params_PSC)\u001b[0m\n\u001b[1;32m    115\u001b[0m Lphase \u001b[38;5;241m=\u001b[39m params_PSC[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mLphase\u001b[39m\u001b[38;5;124m'\u001b[39m]\n\u001b[1;32m    116\u001b[0m lambda_gs \u001b[38;5;241m=\u001b[39m params_PSC[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mlambda_gs\u001b[39m\u001b[38;5;124m'\u001b[39m]\n\u001b[0;32m--> 117\u001b[0m phi \u001b[38;5;241m=\u001b[39m (\u001b[43mx\u001b[49m\u001b[38;5;241;43m/\u001b[39;49m\u001b[43mlambda_gs\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43m \u001b[49m\u001b[43mLphase\u001b[49m) \u001b[38;5;241m%\u001b[39m Lphase\n\u001b[1;32m    118\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m phi\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import os\n",
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm  # 用于显示进度条\n",
    "\n",
    "torch.manual_seed(1)\n",
    "exp_type = 'cth'\n",
    "save_path = os.path.join('./results/', exp_type)\n",
    "os.makedirs(save_path, exist_ok=True)\n",
    "\n",
    "### initialize LSC and PSC\n",
    "LSCModel = LSC(params_LSC).to(device)\n",
    "PSCModel = PSC(params_PSC).to(device)\n",
    "\n",
    "### stimulus and ground truth position\n",
    "pos_gt = torch.tensor(30., dtype=torch.float32)  # ground truth position\n",
    "pos_gt = pos_gt.to(device)\n",
    "phi_gt = position2phase_modules(pos_gt, params_PSC)\n",
    "\n",
    "pos_gt_np = pos_gt.detach().cpu().clone().numpy()\n",
    "phi_gt_np = phi_gt.detach().cpu().clone().numpy()\n",
    "\n",
    "# total_iterations = 5000\n",
    "# n_methods = 3\n",
    "num_simulation = 1000\n",
    "num_rate = 15\n",
    "rate_ampl_all = np.linspace(0, 10, num_rate)\n",
    "z_decode_psc_mean = np.zeros(num_rate)\n",
    "z_decode_psc_gop_mean = np.zeros(num_rate)\n",
    "z_decode_lsc_mean = np.zeros(num_rate)\n",
    "z_decode_psc_std = np.zeros(num_rate)\n",
    "z_decode_psc_gop_std = np.zeros(num_rate)\n",
    "z_decode_lsc_std = np.zeros(num_rate)\n",
    "g_noise_stre = np.zeros(num_rate)\n",
    "p_noise_stre = np.zeros(num_rate)\n",
    "\n",
    "for j in tqdm(range(num_rate), desc='Rate Amplitude Loop'):\n",
    "    rate_ampl = rate_ampl_all[j]\n",
    "    z_decode_psc = np.zeros(num_simulation)\n",
    "    z_decode_psc_gop = np.zeros(int(num_simulation/50))\n",
    "    z_decode_lsc = np.zeros(num_simulation)\n",
    "    sigma_g0 = np.array(PSCModel.sigma_g)[0]\n",
    "    sigma_p0 = np.array(LSCModel.sigma_p)\n",
    "    pg_ratio = sigma_g0 / sigma_p0\n",
    "    g_noise = np.array(PSCModel.sigma_g * rate_ampl)\n",
    "    p_noise = np.array(LSCModel.sigma_p * rate_ampl * pg_ratio)\n",
    "    phi_noise = np.array(PSCModel.sigma_phi * phi_ampl)\n",
    "    for i in tqdm(range(num_simulation), desc=f'Simulation Loop for Rate Amplitude {rate_ampl}', leave=True):\n",
    "\n",
    "        phi_ampl = 5.0\n",
    "        # activation_p = LSCModel.forward(pos_gt, noiseFlag=True, rate_ampl=rate_ampl * pg_ratio)\n",
    "        # activation_gs = PSCModel.forward(pos_gt, noiseFlag=True, rate_ampl=rate_ampl, phi_ampl=phi_ampl)\n",
    "        activation_p = LSCModel.forward(pos_gt, noiseFlag=True, rate_ampl=rate_ampl)\n",
    "        activation_gs = PSCModel.forward(pos_gt, noiseFlag=True, rate_ampl=rate_ampl, phi_ampl=0.5)\n",
    "\n",
    "        ### PSC MAP decoding\n",
    "        z_est_MAP, phi_est_MAP = Simplified_PSC_MAP_decoder(PSCModel, activation_gs)\n",
    "        z_place_MAP = LSC_MAP_decoder(LSCModel, activation_p)\n",
    "        z_decode_psc[i] = z_est_MAP\n",
    "        z_decode_lsc[i] = z_place_MAP\n",
    "        # z_ts = torch.stack(z_ts).detach().cpu().numpy() # shape [total_iterations+1, 1]\n",
    "        # phi_ts = torch.stack(phi_ts).detach().cpu().numpy() # shape [total_iterations+1, M]\n",
    "        # plt.plot(z_ts)\n",
    "        if i % 50 == 0:\n",
    "            ### PSC GOP decoding\n",
    "            z_t = pos_gt # previous position\n",
    "            phi_t = position2phase_modules(z_t, params_PSC)\n",
    "            z_ts, phi_ts = PSC_GOP_decoder(PSCModel, total_iterations, z_t, phi_t, activation_gs)\n",
    "            z_gop = np.array(z_ts)\n",
    "            z_decode_psc_gop[i//50] = z_gop[-1]\n",
    "\n",
    "    error_psc = np.abs(z_decode_psc - 30)\n",
    "    error_psc_gop = np.abs(z_decode_psc_gop - 30)\n",
    "    error_lsc = np.abs(z_decode_lsc - 30)\n",
    "\n",
    "    g_noise_stre[j] = g_noise[0]\n",
    "    p_noise_stre[j] = p_noise\n",
    "\n",
    "    z_decode_psc_mean[j] = np.mean(error_psc)\n",
    "    z_decode_psc_gop_mean[j] = np.mean(error_psc_gop)\n",
    "    z_decode_lsc_mean[j] = np.mean(error_lsc)\n",
    "\n",
    "    z_decode_psc_std[j] = np.std(error_psc)\n",
    "    z_decode_psc_gop_std[j] = np.std(error_psc_gop)\n",
    "    z_decode_lsc_std[j] = np.std(error_lsc)\n",
    "\n",
    "# 保存结果\n",
    "np.save(os.path.join(save_path, 'z_decode_psc_mean.npy'), z_decode_psc_mean)\n",
    "np.save(os.path.join(save_path, 'z_decode_lsc_mean.npy'), z_decode_lsc_mean)\n",
    "np.save(os.path.join(save_path, 'z_decode_psc_gop_mean.npy'), z_decode_psc_gop_mean)\n",
    "np.save(os.path.join(save_path, 'z_decode_psc_std.npy'), z_decode_psc_std)\n",
    "np.save(os.path.join(save_path, 'z_decode_lsc_std.npy'), z_decode_lsc_std)\n",
    "np.save(os.path.join(save_path, 'z_decode_psc_gop_std.npy'), z_decode_psc_gop_std)\n",
    "\n",
    "# 绘制带阴影误差条的图\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYAAAAGACAYAAACkx7W/AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAA9hAAAPYQGoP6dpAABcy0lEQVR4nO3deVxU9f4/8NcM+7DKLgJuKO6hornjihuaWy6Zqd1uan4tMzPJFa9X0/xVtzLzammZJjdzTw0yNbc0MZc0xV0U2fd9mPn8/nh7gBGQGQRmez8fj3nAnHNm+HAYPu9zPsv7IxNCCDDGGDM7cn0XgDHGmH5wAGCMMTPFAYAxxswUBwDGGDNTHAAYY8xMcQBgjDEzxQGAMcbMFAcAxhgzU5b6LkBNUKvViI+Ph6OjI2Qymb6LwxhjeiOEQHZ2Nnx8fCCXP/0a3yQCQHx8PPz8/PRdDMYYMxhxcXHw9fV96jEmEQAcHR0B0C/s5OSk9euUSiWioqIQGhoKKyur2iqe2ePzXDf4PNcdQz7XWVlZ8PPzK6kXn8YkAoDU7OPk5KRzAFAoFHBycjK4P6Ip4fNcN/g81x1jONfaNIdzJzBjjJkpDgCMMWamOAAwxpiZ4gDAGGNmyiQ6gXWhUqmgVCoBUEeOpaUlCgoKoFKp9Fwy02Us59nKygoWFhb6LgZjdcZsAoAQAgkJCcjMzIS0CJoQAt7e3oiLi+MJZLXIWM6zTCaDs7MzvL29DbqcjNUUswkAmZmZyMjIgIeHB+zt7SGTyaBWq5GTkwMHB4cqZ8yx6jOG8yyEQG5uLpKTk2FnZwcXFxd9F4mxWmcWAUAIgaSkJDg5OcHd3b1ku1qtRlFREWxtbQ22YjIFxnKe7ezsUFhYiKSkJDg7O/NdADN5hvvfWINUKhVUKpVOk8SYeXJycir5vDBm6swiABQXFwMALC3N4oaHPQPpMyJ9ZhgzZWYRACR8S8+qwp8RZk7MKgAwxpgxyMsD/voLyM6u3Z/DAcBEXLt2DbNmzULz5s2hUCjg7OyMrl27Yu3atSXzHp5m8+bNkMlkuHv3bqXH3L17FzKZDJs3b665gmvxc7QpG2OmoLgYuHYN2LkT+PVXIDm5dn8eN4qbgMjISEydOhUtWrTAO++8g8DAQOTl5eHAgQOYM2cODh48iH379j21eWPo0KE4ffo06tevX4clZ4wBgBDAgwfA+fPAzZuAQgEUFdX+z+UAYOSuXbuGqVOnYsCAAfjxxx81OrqHDBmCPn36YMyYMdi+fTsmTJhQ6ft4eHjAw8OjLorMGCsjLQ24eBG4coXuABo2BGxsgNjY2v/Z3ARk5FavXg25XI4NGzZUOMpp9OjReOWVVzTG38tkMkRERKBTp05wdnbG8uXLK2xm2blzJ5577jnY2dmhQ4cOuHDhglZlio6ORq9eveDg4ID69etj+vTpyMjIKNl///59TJgwAa6urlAoFOjXrx/+/PNPrX/nlJQUvPzyy/D29oatrS2CgoKwZcsWrV/PmCEoKABiYqi5JyYGcHUFmjalyr+umPUdgBBAbi5gYQEYwvwkhQLQdRDK7t270a9fP3h6elZ6zDfffFNu2/Lly7F8+XK0bdsWfn5+iImJ0di/b98+jBkzBuPHj8eqVatw4cIFTJo0qcryHDx4EGFhYRg+fDgiIyORnp6Od999F9evX8eRI0eQkpKCbt26QaFQ4PPPP4e9vT0++eQT9OrVC2fPnkXLli2r/BkTJ05EUlISvvzySzg5OWHLli145ZVX4Ofnh969e1f5esb0SaUCbt2iSv/BA8DNDWjeXPf//Zpg1gEgLw/w9XXRdzFK5OQA9vbaH5+eno709HQ0b9683L4nx7HLZDKNRGfPP/883nvvvZLnTwaAZcuWoWPHjti2bRsAYNCgQZDJZJg/f/5Ty7R48WI899xz2LVrV8k2GxsbhIeHIz4+HuvWrUNqaipOnjyJhg0bAgAGDx6Mli1bYvHixfjhhx+q/L2PHTuGRYsWYcSIEQCA3r17w83Njed5MIMXH0/t/Ddu0JV+s2Z0AaovBnDdy6pLrVZXuP3mzZuwsrLSeDRt2lTjmLZt21b6vvn5+YiJicELL7ygsX3s2LFPLY/0upEjR2psHz16NM6dOwcfHx8cPnwYQUFBaNCgAYqLi1FcXAy5XI7BgwcjOjr6qe8v6dOnD5YsWYKxY8di8+bNSE5Oxpo1a9CjRw+tXs9YXcvMBI4dA3btosrf1xfw89Nv5Q+Y+R2AQgE8eJABJycng8hRo1DodrybmxscHBzKDY/08/PDH3/8UfI8IiICly9f1jjGy8ur0vdNT0+HEKJcp3BVI4TS0tIghHhqc1RqampJgKpIXl7eU38GAGzfvh0rVqxAZGQkfvjhB8jlcgwYMADr1q1D48aNq3w9Y3WlsBD4+2+66k9NBXx8AEPKSGPWAUAmoyYXe3vD6AOojhdeeAF79+5FdnY2HB0dAVCTS3BwcMkxbm5uOr2nq6sr5HI5EhMTNbanpqY+9XVSArXkJwYvFxYWIjo6Gr1794aLiwtCQkKwZs2aCt/DRoseMGdnZ6xatQqrVq3C9evXsWfPHixbtgxvvPEGDh48WOXrGattajVw+zZV/PfvAy4uQGCgbu38+fm1VrwSRlrtMUl4eDiKi4vx6quvoqiCgcP5+fm4ffu2Tu9pa2uLbt264ccffyxZOwGgjuGncXBwQFBQEPbs2aOxPSoqCmPHjkVcXBxCQkJw/fp1NG/eHMHBwSWP7777Dhs3bqxyQZZ79+7Bz88PO3bsAAAEBgZi3rx5GDBgAOLi4nT6PRmrDQkJwM8/A/v300Supk0BLy/tK/+sLODLL4F//5veqzaZ9R2AKWjdujW2bduGyZMnIygoCK+//jratm2L4uJinDp1Cl999RUSEhIwb948nd53xYoV6Nu3L0aNGoVp06YhNjYWy5cvr/J1y5Ytw/DhwzFu3DhMnToVSUlJCA8Px8CBAxEUFARvb29s2bIF/fv3x9y5c+Hm5obIyEhs2LABH3/8cZXv37BhQ/j6+uLNN99EVlYWmjZtinPnzuHAgQMIDw/X6XdkrCZlZ9N4/suX6erd1xews9P+9SoVcPAgsG0bDQgBKJB061Y75QU4AJiEESNG4NKlS1i3bh02btyIe/fuQa1Wo2nTphg3bhymT5+OZs2a6fSePXv2xMGDB/H+++9j5MiRaNy4Mb7++msMGzbsqa8LCwvD/v37sXTpUowYMQLu7u548cUXMXfuXACAj48PTp06hfDwcEyfPh0FBQVo3rw5vvrqK7z66qtalW3Xrl0IDw/HokWLkJKSAj8/PyxZsqTKEUqM1Qa1Grh6lYZ1JiYC3t5U+evi4kVgwwZqLgJoMtjgwcDkyTVf3rJkouw9vpHKysqCs7MzMjMzK8z5X1BQgDt37qBx48awtbUt2a5Wq5GVlWUwncCmypjOc2WfFWOgVCpx4MABDBkypNJOdlYzpHMdGjoE589b4cwZwMGBmnp0+Yg/egRs2gT8/js9d3QEXn4ZCA2luQIjRwJNmuhWtqrqw7L4DoAxxqrp99/pyr9+fd1G9+TlATt2ALt3U/oHuRwYOhQYP56CQF3hAMAYYzoqLKSv589Tc4+2EzjVauDoUeDbbykHEAAEBQGvvQb4+9dGSZ+OAwBjjOkgJwc4coS+9/PTvqP3+nVq55eSvHl7A//4B9C5s37SQAAcABhjTGuZmcDhw8CdO0BAAKBNN1FqKl3xS0HDzg4YOxYYPhzQd1cNBwDGGNNCSgot0nL/vnYds0VFwJ49wA8/UOZPAOjXD5g0iTJ/GgIOAIwxVoVHj+jKPymJrvzlcsomXBEhgDNngK+/Lp3IFRgIvP46JX8zJBwAGGPsKe7fpyv/jAya1fu0yv/+fWrnv3iRnru60lj+kBDDTDfDAYAxxipx8ya13RcUULNPZZ212dk0g/fgQRrpY2VFY/hHj9ZtNnBd4wDAGGNPEIKyeB47Rs8bNar82CNHgI0bKQgAQNeuwNSpNMqnOgoLgbg4mlhW26uDcQBgjLEyhAAuXACOH6er98oqciGA//1PjsdrJqFhQxrP/9xz1fu5KhX1NeTnU19Bhw5AgwbVey9tGWCrFNNF7969IZPJNB7W1tbw9/fHzJkzkZ6ernGsKS2ZePfuXchkMmzevBkAKlzXmDFdqFTA2bM0WcvJqfLKX60GNmxoi23bKHvtmDHAJ59Uv/JPTaX5AU5OwJAh9Kjtyh/gOwCT0L59e3zxxRclz4uKihATE4P3338ff/75J06ePAmZvmaaMGYklErg9Gngjz8AT0/K4V/ZcR9/bIETJ2gs6OuvA2Fh1fuZubm0LrCTE3UUt22r+8JQz4IDgAlwcnJCly5dNLb16tULOTk5WLx4Mc6cOVNuP2OsVGEhNflcuECrdlWWjycvD1i5Erh4UQ5LSzXeekuNkBDdq1Glkip+IYB27ai5x9392X6H6uAmIBMmrQp27969CvenpKRg5syZaNiwIaytreHq6oqRI0eWa0LZvn07goODoVAo4O/vj/feew+FUjIUAH/99RfCwsLg5OQEJycnjBw5UqtFaKKjo9GrVy84ODigfv36mDZtmkaT1f379zFhwgS4urpCoVCgX79++PPPP7X+/VNSUvDyyy/D29sbtra2CAoKwpYtW7R+PTMPeXk0zPPPPym1Q2WVf2YmsHAhDfG0tRVYsOB39OqlWzJltZrmBty5Q4Fm+HBgwAD9VP6Aud8BCEH3YBYWhjFIV6Go0aQg169fB4ByC8IDgBACQ4cORVpaGj744APUr18fFy5cwKJFi/D6668jKioKALB+/XpMnz4d//jHP/Dvf/8bd+7cwbvvvouUlBR89dVXiI2NRbdu3dCiRQts3rwZKpUKy5cvR/fu3XHx4sVK1wc+ePAgwsLCMHz4cERGRiI9PR3vvvsubt68icOHDyMlJQXdunWDQqHA559/Dnt7e3zyySfo1asXzp49i5YtW1b5+0+cOBFJSUn48ssv4eTkhC1btuCVV16Bn5+fSfWFsOrLyqL2/uvXgcaNKx91k5gILFkCxMdTgFi8WIVmzZIrPrgSmZnUyevuTpV+ixaAtfWz/w7PwrwDQF4eXHRduaE25eRon1awDCEEiouLS56npaXh2LFjWL58Obp06YKOHTuWe82jR49gb2+PNWvWoGfPngCok/j27dtYv349AMrjv2TJEowcORIbN24seW1BQQE2b96MwsJCREREwM7ODr/88ktJ7vF+/fqhSZMm+PDDD/Hhhx9WWObFixfjueeew65du0q22dnZITw8HPHx8Vi7di1SU1Nx8uRJNGzYEAAwePBgtGzZEosXL8YPP/xQ5Xk5duwYFi1ahBEjRpT8fm5ubrC0NO+PPSNpaXTlf+cOTfCqLC/P3bvA0qV0vIcHEBEBNGggKp0M9qSCAmrusbGhxG/t2xvOwvD8n2ACfvvtt3ILgMjlcvTr1w8bNmyosAPYx8cHv/76KwBqarl58yauXr2KkydPlqwtHBsbi8TERIwcOVLjtbNnz8bs2bMBAIcPH0afPn2gUChKgpCTkxN69uyJ6OjoCsubn5+PmJgYREREaGwfPXo0Ro8eXfK+QUFBaNCgQcn7yuVyDB48GN99951W56VPnz5YsmQJLl68iCFDhmDw4MGVLkbPzEtiIlX+8fGU2qGya4KrV4F//YsaCvz9qfJ3c6t8JnBZZYd1Nm9O7fw+PjX7ezwrgwgAGzZswCeffIK7d+/C398f//d//4c33nij9keuKBTIePDAcFaqqmb3f4cOHUqu2mUyGWxtbeHv7w/HKlaW2Lp1K8LDwxEXFwdXV1cEBQVBUaYMqampAFBpM450TGRkJCIjI8vt8/DwqPA1aWlpEEJU+b43b96sdGWrvLy8Sl8r2b59O1asWIHIyEj88MMPkMvlGDBgANatW4fGjRtX+Xpmmh48oMo/NZWu/C0sKj7u7Flg9WpK6taiBbBokfaLtaSk0KNBA6BvXwoylf0cfdJ7ANi4cSNef/11zJo1Cy+88AKOHTuGWbNmIT8/v2Qd2Vojk1GTi729YfQBVJOjo2NJh6+2Tpw4gVdeeQWzZs3C3Llz4fu4KWzevHk4ceIEAMDl8Ti45GTNts60tDTExMSga9eucHFxQf/+/fHOO++U+xmVNbU4OztDJpOVe9/CwkL8+uuv6Ny5M1xcXBASElLpFbuNFlMknZ2dsWrVKqxatQrXr1/Hnj17sGzZMrzxxhs4ePBgla9npicvj2buSnl9KrvG/OUX4PPPqdO2Uydg3jztZuXm5AAPHwLOzjSss02buh3WqSu913pff/01unfvjk8//RT9+vXDsmXLMHbsWKxdu1bfRTNpp06dglqtRkREREnlr1KpSppt1Go1WrRoAXd3d+zevVvjtVu3bsXgwYNRUFCAkJAQXL16FUFBQQgODkZwcDA6duyIjz/+WKN9vywHBwcEBQVhz549GtujoqIwZMgQxMXFISQkBNevX0fz5s1L3jc4OBjfffcdNm7cCIsqLqfu3bsHPz8/7NixAwAQGBiIefPmYcCAAYiLi6vOKWMmID4eSE6m5pyKKn8hgB9/BD79lCr/vn2B8PCqK3+lkvoKkpNpWOfIkdTeb8iVP2AAdwCFhYXwfmK6nbu7e0nzA6sdnTt3BgD83//9H1599VWkp6fj888/x8XHaQxzc3Ph6OiIiIgIzJw5E2+88QZGjhyJGzduYOHChZgxYwbc3d2xePFidO3aFWFhYZgxYwZsbW2xfv167N69u6TyrciyZcswfPhwjBs3DlOnTkVSUhLCw8MRFhaGoKAgeHp6YsuWLejfvz/mzp0LNzc3REZGYsOGDfj444+r/P0aNmwIX19fvPnmm8jKykLTpk1x7tw5HDhwAOHh4TVzEpnRuXePKv6Krh/UalqgXbouGTWKMnlW1RKdnU1X/U2aAB07UkoIY5l3qfc7gLfffhtRUVH47rvvkJmZiZ9//hnffPMNJk2apO+imbTevXtj7dq1OHXqFAYPHoy3334b/v7+2LlzJwDg+PHjAIA33ngDmzdvxm+//YawsDCsWbMGc+fOxUcffQQAaNeuHY4fPw6ZTIZJkyZhzJgxePToEXbv3o1Ro0ZV+vPDwsKwf/9+3LlzByNGjMD777+PsWPH4vvvvwdAndSnTp1Co0aNMH36dAwbNgxnz57FV199VdIBXZVdu3Zh4MCBWLRoEUJDQ7Fu3TosWbIEixcvfoYzx4xVbi5dpderV35fcTGlcpAq/6lTgSlTqq7IMzJoXH+XLsCwYZQ0zlgqfwCQCaHtYKbaUVhYiBkzZmDTpk0l2wYOHIh9+/ZV2gFYWFioMREpKysLfn5+SElJKRmKWFZBQQHi4uLQqFEj2JZZw00IgezsbDg6OnKqhFpkTOe5oKAAd+/ehZ+fn8ZnxRgolUpER0djwIABlf7vmLNbt4ADB+hKvWyXX0EBsHq1BWJi5JDLBWbNUqFv36dXi0IoAUTj/v0B6NzZCkFBhtONmJWVBXd3d2RmZlZYH5al9wAwaNAgnDx5EosXL0bnzp1x6dIlLF26FD179sSuXbsqrDCWLl1abgghAGzbtk1jFIvE0tIS3t7e8PPzg7W+Z14wg1ZUVIS4uDgkJCRozK1gpikrywr//ncXXL/uCmvrYsyb9weCg5P0XaxnkpeXh5deesnwA8CpU6fQvXt3bNiwAa+99lrJ9p9++glhYWHYt28fwirIssR3AMbFmM4z3wGYptxc6ty1sipN8pacDCxdaokHD2RwcBBYtEiFFi2quvKnVb8UCiXc3Q3zXOtyB6DXTmApR0337t01toeEhAAArly5UmEAsLGxqXAYoJWVVYV/DJVKBZlMBrlcrjHeX61WA0DJPlY7jOk8y+VyyGSySj9LxsCYy15bkpKovT4ggNro4+IotUNKCk3sioiQwd//6dWhWg3cvk3LPPbqBVy6ZJjnWpfy6PW/sUWLFgBKOxwlJ0+eBACerMMYqxF375am/Lp2DZg/nyp/X1+a7OXv//TXFxcDN24AXl7AoEH0OlOg1zuA9u3bY/To0ZgzZw7S09Px/PPP48qVK1i6dCk6dOhQLgUBY4zpKjubmm1cXSnj54oVlP65eXNg8eKq8/IUFVG+oMaNgT596H2Uyrope23T+/34tm3bMGfOHHz55ZcYOHAgPvnkE0ydOhXHjh0zuFsrxpjxiY+nTJwKBbBmDVX+7dsDy5dXXfnn59PoocBAIDSUKn9ToveJYNbW1li2bBmWLVtW6z9LzwOemBHgz4jpuXuXkr1duEB3A66ulNe/quvLnBzKGxQURG3+RjYmQCt6vwOoC9KdhDYJxJh5kz4jfPdpGrKySpt/Hqe4Qo8eVVf+6el059C5MzX7mGLlDxjAHUBdsLCwgIuLC5KSaHyvQqGATCaDWq1GUVERCgoKDH50ijEzhvMshEBeXh6SkpLg4uJSZa4hZhzi4ykIODsDZ87Qth49nv6a5GR6TY8eQHCwYWbxrClmEQAAlOQbkoIAQP/0+fn5sLOzM/jx6cbMmM6zi4tLudxUzHjduUNX++fP04xfT09qz69MfDyN+OnTh5K6GfjH9ZmZTQCQyWSoX78+PD09oXzcha9UKvHbb7+hV69efMtfi4zlPFtZWfGVvwnJzKTx/q6ugLRcRY8elWcBvX+fgkX//k8PEqbEbAKAxMLCouSf3MLCAsXFxbC1tTXoisnY8Xlm+iA1/zg5AefO0bbHq59qUKvpTsHJidI/N2pUp8XUK7MLAIwx83DrFi26/scfNJbfx4cSwZWlUtFx3t5U+devr5+y6oth9sgxxtgzyMigHP1uboCUaKBnT83mH6USuHkT8POj2b3mVvkDfAfAGDNB8fE05t/RkWb/AprNPwUF1OzTogXQu3fVE8JMFQcAxphJEYKSttnYAL//TqN6GjYszfcjTfBq144meBn6so21iQMAY8ykZGRQBf/k5C+Amn0ePKDx/d27Ux+BOeM+AMaYSYmPp6t8tRp4vMR1SfNPejpl9OzWjSt/gAMAY8yECEEdu7a2wOnTFAQCAmgEEEB3B02bUvMQ4wDAGDMhUg4fV9fS0T9S809REaV1qCr3vznhAMAYMxlS809hIXDlCm2TAkBaGuDhQWP+GeEAwBgzCULQql0KBXDqFD1v0YLy/wA0KzggoOpMoOaEAwBjzCSkpQEJCZqjf6TO34ICqvj9/PRXPkPEw0AZYybh4UNq/rG2pnV/ZTIa7QOUNv94eem3jIaG7wAYY0ZPGv2jUJRe/bdpQ6kgAJoV3Ly5aef2rw4OAIwxo5eSUtr88+Ton7w8wM4O8PXVX/kMFTcBMcaMXnw8kJtLV/i3bgFyuWbzj6cnNQExTXwHwBgzamo1jf6xty+9+n/uOVoGEqB+gebNKSgwTXxKGGNGLSUFSEzUbP6RRv/k5AAODkCDBvornyHjJiDGmFGLj6d2fmlZR0tLoEsX2peWRmkgpM5gponvABhjRktq/nFwKL3679CBngsB5OcDzZqZ/uLu1cUBgDFmtJKTgaQkoF698pO/pAVhuPmnctwExBgzWlLzj1JJ31tbA5060b7UVFoDuF49/ZbRkPEdAGPMKFXU/BMcTJPB1GrK/tm0qX7LaOg4ADDGjFJSUuXNP1lZNAyUm3+ejgMAY8woPXxISd7i4igQ2NnRHQBAzT/+/ua72Lu2OAAwxoyOSkW5fxwdS5t/Onemlb5UKno0bqzfMhoDDgCMMaMjNf+4uAAnT9I2qfknM5O2c/NP1TgAMMaMzsOHtOrX7ds02cveHmjfnvalpQGNGtE29nQcABhjRkWlotE/ZZt/unShBV9UKpoA1qiRXotoNDgAMMaMSmIiTQBzdqalHwGgVy/6mp5OzT8+PnornlHhAMAYMyoPH9IY/9hYau93cgLataN96ek09t/OTr9lNBYcABhjRqO4mJp/nJxKm3+6daN1AJRKyvnTsKF+y2hMOAAwxoxGYiKlf3Z0BE6fpm3S6J/0dEoJXb++/spnbDgAMMaMxoMH1Pzz99+0ApirK9CqFe3LyAACAmguANMOBwDGmFEoLqbJX87OwG+/0bbu3an5p6iIvvr767eMxoYDAGPMKCQkUPOPQgGcPUvbpOaftDTA3R3w9tZf+YwRBwDGmFF48IDuAv76ixZ68fQEAgNpX2YmLfxiZaXfMhobDgCMMYOnVFLzT9nRP92706ifggJaB8DPT79lNEYcABhjBk9q/rGzA/74g7ZJk7/S0gAPD8DLS3/lM1YcABhjBu/BA0rzcOECdfjWr0+rfQG09GPz5tQJzHTDAYAxZtCKikpH/0jNPz17UvNPXh7dFfj66reMxkrnAPDLL78gNze3NsrCGGPlJCTQAi82NsD587St7OgfT09qAmK60zkATJo0CXv27KmNsjDGWDlxcdT8ExNDo4D8/UvTPeTkUPOPnNsyqkXn02ZjYwNbW9vaKAtjjGmQmn9cXEqbf3r0oK85ObQgPC/8Un2Wur7g/fffx7Rp03Dx4kW0adMGXhV0vfeSuucZY+wZPHpEzTz16lEHMKDZ/OPjA7i56a14Rk/nADB9+nQAwL/+9S8AgEwmK9knhIBMJoNKpaqh4jHGzFlcHC3w8scfgFpNI38aNKBt+fk0+atMFcR0pHMAOHLkSI0X4vfff0d4eDjOnj0LBwcHDBo0CB9++CE8PT1r/GcxxoxDfj5w65Zm84909Z+dzc0/NUHnABASElKjBYiJiUGfPn3Qr18/7Nq1C/Hx8QgPD8eNGzdwSlruhzFmdmJjaeF3NzdK/wCUtv+nptLdQL16+iufKahW33lsbCwmTJgAb29v2NrawtfXFxMmTMC1a9d0fq93330XQUFB2LNnD0JDQzFlyhSsXbsWcXFxuHPnTnWKxxgzcjk51Obv4gKcOUNNPoGBNNtXrabUEE2b6ruUxk/nO4CrV6+iW7dusLKyQlhYGLy9vfHo0SPs378fP/30E86cOYOWLVtq9V6pqak4evQovvnmG1iUmcY3atQojBo1SteiMcZMxJUrdPXfvHlp6mep+ScrixaE4eafZ6dzAJg/fz4aN26Mo0ePwtnZuWR7ZmYm+vbtiwULFmDnzp1avdelS5cghICnpycmTpyIvXv3QgiBESNG4LPPPkM9vr9jzOykpwOXL1N659RU4No16ujt3p32p6YCLVtSYjj2bHQOAMeOHcNXX32lUfkDgLOzM8LDwzFt2jSt3ys5ORkA8Oqrr2Lw4MHYvXs3bty4gfDwcNy6dQsnT56EvIIZHoWFhSgsLCx5npWVBQBQKpVQKpVa/3zpWF1ew3TH57lumMp5vniR0jsHBAC7d8sBWKB1azVcXVVQqagJyN+fmoH0xZDPtS5l0jkAWFlZwaaSNddsbGw0KuaqFBUVAQA6duyIjRs3AgD69esHFxcXTJgwAdHR0Rg4cGC5161cuRIRERHltkdFRUGhUGj98yXR0dE6v4bpjs9z3TCF8xwQQF9PnOgFoB66d78MIe5CJqO2/9hYeuibIZ7rvLw8rY/VOQB06tQJa9euRVhYWLk5AJ999hmCg4O1fi9HR0cAQFhYmMb2QYMGAQAuXLhQYQAIDw/HnDlzSp5nZWXBz88PoaGhcNLhvlCpVCI6OhoDBgyAFa8kUWv4PNcNYz/PQgBHj9KIn4AAmgR286YV5HKBbt1aQSZrhdu3gTZtgBoejKgzQz7XUouINnQOAP/617/QvXt3tGnTBuPGjYO3tzcSEhIQGRmJGzdu4JdfftH6vZo1awYA5e4apFsYOzu7Cl9nY2NT4V2IlZVVtf4Y1X0d0w2f57phrOf5wQO6qq9fn9r8T5yg7e3ayVCvnhVUKsoJ1Lix4az8ZYjnWpfy6DwMNDg4GIcOHYKDgwMiIiIwffp0REREwMHBAYcOHdIpDUTLli3RqFEjbN++XWP73r17AQA9pW5/xphJU6tp2GdxMU3wEqL85K/0dBr37+Ojt2KaHJ3vAL799lv07dsXZ86cQV5eHjIyMuDi4lKttneZTIYPP/wQY8eOxbhx4/Daa6/h2rVreP/99zF69Gi0b99e5/dkjBmfu3cp6ZtUuZ85A9y7R0s9du1K29LTgY4dKf8/qxk63wHMmTMH586dAwAoFAr4+PhUq/KXjBkzBnv37sWdO3cwbNgwrFy5EtOnT8fWrVur/Z6MMeOhVAJ//kkpne3s6C7gm29o3wsv0B2BNLBFSgPNaobOdwCenp7IyMio0UKEhYWV6whmjJmHW7foal+q3KOjgYcPaZy/NB80PZ1SQtSvr79ymiKdA8A///lPzJw5E0eOHKk0HfQrr7xSI4VjjJm2ggK6+rezo+aevDxg2zbaN348YG9P32dkAF260KpgrOboHADeeecdAMCWLVsq3C+TyTgAMMa0EhtLV/tSXp/du2kSWP36gDQCvKiIFnz399dbMU2WzgGAE7QxxmpCbi5d/Ts5AZaWtMDLrl20b/Lk0qGeaWmUFsLbW39lNVU6B4D/+7//w1tvvYX+/fvXRnkYY2bi779LE74B1PRTWEhZP6WRPwDdEbRrZzhj/02JzqOAfvvtN1ha6hw3GGOsREYGjft3c6PRP/fvA9Ic0qlTS1f5KiigvgE/P32V1LTpHABCQ0OxceNGFBQU1EZ5GGNm4K+/aGSPuzs9/+YbmgzWpQvQqlXpcWlpgIcHrQPAap7Ol/K2traIjIzEzp070bhx43KjgGQyGQ4fPlxjBWSMmZbkZAoAXl50pX/5Mq35K5cDT44fyc4GgoOpE5jVPJ0DwIMHD9BdSswNSgJX1pPPGWNMIgSle87JoQVd1Gpg0ybaN2gQ4Otbemx2Ng0PLbuN1SyDWBSeMWYe4uOB69dLUz6cOEEpIOzsgHHjyh8bFAR4etZ5Mc1GtdYErkx+fj7Onz9fk2/JGDMRUsK3oiJa0lGpBKTpRKNGaS7wnppKxwQFlXYIs5qnVQDw9PTEn3/+qbFtxYoVSExM1Nh26dIldOrUqeZKxxgzGffuaSZ8O3AASEwEXF0p549EraZ+gueeK+0kZrVDqwCQkpKiscyYSqXCokWL8PDhw1orGGPMdBQXlyZ8UyioDyAykva99BJga1t6bGIiNfu0aaOfspqTajcBcWcvY0xbt25RymcpmdsPP1AQ8PcH+vUrPU6pBLKygA4dKAsoq1012gfAGGNPKiyktn8bG3okJQH799O+KVM0h3g+fEhZQQMD9VFS88MBgDFWq27coOUepbb/776jK/22bWmBF0l+Pi352KEDzf5ltY8DAGOs1uTmAufPU3OOpSU1BR09SvvKpnwAKEg0a0Zr/rK6oXUAkFUwFquibYwxJrl2jTp1vbxoEtjmzbQ9JAQICCg9LiuLmofat6eOYlY3tJ4INmLECNg8sRrDsGHDYF3mXq2wsLDmSsYYM2qZmaUJ3ywsgJgYmgVsaQm8/HLpcULQpK9OnXjB97qmVQCYPHlyuW0hISE1XhjGmOn46y9K5hYYSG370tV/WJhmcreUFJoE9txzeimmWdMqAGySknUwxpgWUlI0E74dOUITwRwcgLFjS49TqWjWb9++mjOBWd3g1jbGWI0SArh0iZK51atHw0C3bqV9L76oOb7/0SOaG9CypX7Kau44ADDGatSjR7TalzTpa88eusr39KTmH0lRES0C37EjzQ5mdY8DAGOsxqjV1NFbWEhr/WZmAj/+SPsmTdJc1vHhQxryWXY0EKtbHAAYYzXm/n0gNpZy/QPA9u00watpU6Bnz9LjcnPpa4cOvNavPnEAYIzViOJiGvYJUJNOfDxw6BA9nzpVc3z/w4c0OqhhwzovJitD5wVhfvvtt0r3yeVyODg4oEmTJnBycnqmgjHGjMudO8Dt25TgDQC+/ZZG+QQHA+3alR6Xng7Y23Ouf0OgcwDo3bu3xgxgIUS5GcFyuRyTJ0/G+vXrYcGLeTJm8oqKKN2zlPDt2jXg1Cm66i87jUitBhISgO7deaF3Q6BzE9DevXtha2uL119/HUeOHMG1a9dw7NgxzJo1C1ZWVvj444/xySef4Mcff8QHH3xQG2VmjBmYe/eAuDga+SME8PXXtL1fP81mnqQkWuSlbVv9lJNp0vkOYNWqVZgxYwbWrFlTsq158+bo0aMHHBwcsHPnThw9ehRqtRqff/45FixYUKMFZowZFrWahn1aWdHj9Gm6A7C2psVeJMXFNCpowAAaIcT0T+c7gJiYGAwaNKjCfb1798aZM2cAAEFBQbh///6zlY4xZvASEugOwMuLKvlvv6XtI0ZQHiBJfDzg68u5/g2JzgGgfv36OHLkSIX7jh49Ck9PTwC0jKSLi8szFY4xZvhu3KA+AIUCiIqiET7OzrTQu6SggI7p0EFz+UemXzo3Ac2YMQPz589HXl4exowZA09PTyQlJWHnzp347LPPsHTpUjx48ADLly9Hnz59aqPMjDEDkZlJ4/49PGhW7/ff0/YJEzRn9z58SBO+mjbVTzlZxXQOAHPnzkVeXh5WrVqFTz/9FACNBHJ2dkZERATCw8OxZcsWFBYWYuXKlTVeYMaY4bh9G8jIoGadrVspIDRoAISGlh6TnU0poNu311z+kemfzgEAABYvXoy5c+fi1KlTSElJga+vL4KCguDwOMvTSy+9hEmTJtVoQRljhqWwELhyhTp009KA3btp+yuvUIUPlOb6b9++dHYwMxzVCgAAoFAo0L9//wr38dh/xkzf/fs0rLNxY2DdOmrjb9kS6NKl9Ji0NAoQPOnLMOncCZycnIyJEyfC2dkZlpaWsLCw0HhYWlY7pjDGjIQ09NPSknL/Hz5M28uu86tSAcnJtNBL2dFAzHDoXFu/8cYb+OmnnzBhwgT4+vpCzgt4MmZ2yg793LaNAkL79kCLFqXHSGsBt2mjv3Kyp9M5ABw6dAiffPIJXn/99dooD2PMCEhDPwEgOpq+vvBC6X6lkjp/u3envD/MMOl8+W5tbY0mTZrURlkYY0ag7NDP6GhK9+znR3cAkgcPgEaNgObN9VZMpgWdA8CoUaPwvTTYlzFmdqShn46OwP79tG3YsNK2/7w8ahLq0IHSQTDDpXMTUIcOHbBgwQLcunULXbp0geKJtdxkMhkWLVpUYwVkjBkOaeinszPwxx/Uzu/oCJSd8/nwIY0GatRIb8VkWtI5AMycORMArQtQ0doAHAAYM11lh37+5z+0bdAgSgENUPOQrS0N++TxIYZP5wCgVqtroxyMMQOnVgNXr9LQz7t3S78fMoT2C0Gjgzp1Kl0Qnhk2jtGMMa08elQ69HPvXtrWo0fpGP+UFKBePRr3z4yDVncAffv2xRdffIEWLVqgb9++Tz1WJpPhsDQrhDFmMm7coOGd+fnA8eO0bfhw+qpSAampQN++ACcBNh5aBQAhRMn3arW63BKQlR3LGDMNGRkUADw8gJ9+ogq/VSvK8AnQjF8vL9rGjIdWAaBs/v+jR4/WVlkYYwZKGvrZqBFw8CBtk67+haB9/foBdnZ6KiCrFu4DYIw9VWEhdfg6OwPHjtEMX09P4PnnaX9aGrX9S3cDzHhodQfQuHHjpzb7POn27dvVLhBjzLDcu0fj/Rs3Lu38HTasNLd/cjLQrRuv82uMtAoAISEhJQFArVZj+/btcHZ2xpAhQ1C/fn2kpqYiKioKycnJmDZtWq0WmDFWd8ou+H75MhAXR808AwbQ/qwswMEBaNZMv+Vk1aNVANi8eXPJ9/Pnz8fzzz+PQ4cOacwCViqVGD58OHJycmq8kIwx/Sg79PObb2hb//6lyz0mJlK2z8dLgTMjo3MfwIYNG/Dee++VSwFhZWWFN998E5GRkc9UoFGjRqERzyFnzCBIQz9TU4Hz5ynfz7BhtC8/nyaCtWyp3zKy6tM5AMhkMiQnJ1e47969e7C1ta12Yb777jvs2rWr2q9njNWcjIzSrJ/79tG2558HvL3p+4QEwN+fl3o0ZjoHgGHDhmH+/Pk4dOhQyTYhBHbt2oUFCxZg/Pjx1SpIfHw83nzzTfj6+lbr9YyxmnX7NuX2kcuBX3+lbdLQT6USKC4GWrfmnD/GTOdcQB9//DGuXr2KIUOGwNraGm5ubkhJSUFxcTFCQ0OxatWqahXktddeQ2hoKGxtbXmuAWN6VnboZ1QULf7StClV+AC1/devzxk/jZ3OAcDFxQW///47Dhw4gOPHjyM9PR3u7u7o169flWkiKrNx40bExMTgypUrmDt3brXegzFWc6Shn35+NPMXoKt/mYxmAefkAD170uggZryqtYK7TCbD0KFD0adPH2RlZcHNzQ1W1fwk3Lt3D3PmzMGmTZvg7u6u1WsKCwtRWFhY8jwrKwsAjURSKpVa/2zpWF1ew3TH57lu1NR5lrJ+WlsDv/8uQ1qaJerVE+jevRhC0MQvd3cKDub6JzXkz7QuZapWADh+/DjmzZuHP/74oyT3T+fOnbFixQr0KbsyRBWEEHj11VcxZMgQjB49WuvXrVy5EhEREeW2R0VFlRudpI1oaVFTVqv4PNeNmjjPMhlV8J9+2gtAPQwefA2WlrEQojT7J7fUGuZnOi8vT+tjdQ4Ap06dQv/+/dGkSRMsWrQI3t7eiI+Px/bt2zFw4EAcO3YMXbt21eq91q5di0uXLuHy5csoLi4GUJpMrri4GHK5HPIKepjCw8MxZ86ckudZWVnw8/NDaGgonHSYjqhUKhEdHY0BAwZU+w6GVY3Pc92oqfN84gRw4QJQWCjDzZuWsLYWGDw4ADJZADIyqH9gxAjzzvppyJ9pqUVEGzoHgIULF6Jnz574+eefYSHNBQewZMkSDBw4EEuWLEFUVJRW77Vjxw6kpKSgfgWrR1hZWWHJkiVYunRpuX02NjawkZYgeuI11fljVPd1TDd8nuvGs5xnKeunmxuwfj1t691bBmdner/kZKBjRxoaygzzM61LeXQOAGfPnsX333+vUfkDgFwux6xZs/DKK69o/V7r169Hdna2xraIiAjExMRg79698PHx0bV4jLFnIA39lMmA33+nbdLQz5wcWu4xMFB/5WM1S+cA4OjoWGknQ1FRkU7rAQRW8Elyc3ODtbU1goODdS0aY+wZSEM/XVxo5I9aDbRvT5O9ABoVFBhYOhGMGT+dp3B0794dK1asKJfzJzs7GytXrkTPnj1rrHCMsbojDf20twekvk3p6l8adNeyJd0dMNOg8x3ABx98gI4dO6JJkyYICwuDt7c3EhISsH//fhQUFGDTpk3PVKCyiecYY3Wj7NDPI0eAvDzA15fuAAAKDL6+NDKImQ6dA0BAQABOnz6NiIgIHDhwAGlpaXB1dUWfPn2wZMkStOI14RgzOo8eAffvU+fu/v20bdgwSvNQXAwUFFDWzye6/piRq9Y8gFatWuE///kPvB83BqalpeHBgwdc+TNmpGJjqaL/6y9K8ubgQAu8A0BSEqWD5rQPpkfnPoCMjAwMGDAAvXv3Ltl29uxZBAUFYcSIETpNQmCM6V96Og39dHcvXfFr4EDAxoaahrKy6Or/GRL9MgOlcwCYP38+rly5ghUrVpRs69u3L/bs2YNz585h8eLFNVpAxljtkhZ8T0ujOwALCyAsjPalpQGurpQIjpkenQPA3r17sWbNGowaNapkm7W1NYYNG4YVK1bgf//7X40WkDFWewoKaMnHevVKr/579ChN95CSArRqBTg66q+MrPboHACys7NRr169Cvd5eXkhJSXlmQvFGKsb9+5Rm79cDhw/TtukoZ+ZmdQXEBCgv/Kx2qVzAOjQoQO++uqrCvdt2rQJ7dq1e+ZCMcZqnzT008aGcv4XF9M4f2mB96Qk+p7TPpiuauUCGjx4MIKDgzFy5Eh4enoiOTkZe/bsQUxMDPZLY8gYYwYtPh6Ii6M2fmmBP+nqPy+P1vtt0UJ/5WO1T+cAMGDAAOzbtw+LFy/G4sWLIYSATCZDUFAQ9uzZg0GDBtVGORljNezGDbrqP3OGRvp4egJdutC+hASgcWOA03GZtmrNAxg8eDAGDx6MgoICpKWlwdnZGfb29jVdNsZYLUlPp7H/bm7Af/5D24YOpRFARUW06lerVrzer6mr9p/377//xn//+1989tlnyMjIwIkTJ8pl9mSMGabbt+mq/949mgFsZweEhtK+pCSgQQOgYUP9lpHVPp3vAFQqFaZPn46vv/66pPnnxRdfREREBG7fvo1jx47B19e3NsrKGKsBBQXAlSuU9TMykrb1709J4FQqIDcX6NWL1/s1BzrfASxfvhxbt27Fxo0bkZCQUJL++f/9v/8HlUqFBQsW1HghGWM15/ZtusovKABiYii7pzTxKzmZRv00bqzfMrK6oXMA+Prrr7Fs2TJMnToVbtJsEQDt2rXDsmXLDHKNTMYYKSoCLl6kq/0DB2hb585A/fqAENQ30Lo1UI2ltZkR0jkAJCYmIigoqMJ9vr6+SE9Pf9YyMcZqye3bwMOHVMH/+ittk4Z+pqfTjGCe+GU+dA4AAQEBOCBdOjzh6NGjCOBPD2MGSakELl2iDt9ff6W7gcaNKdEbQM0/gYHmvdi7udG5E3j27NmYNm0aioqKMGzYMMhkMty4cQNHjhzBmjVr8NFHH9VGORljz+j2beDBA1rY5aefaNvw4dQHkJ1NgaF5c/2WkdUtnQPAa6+9huTkZPz73//GunXrIITAhAkTYG1tjXnz5mH69Om1UU7G2DMoLqarfxsb4OxZIDWVrvR79aL9SUk069fLS6/FZHWsWhPBwsPDMXPmTJw+fRqpqalwcXFBly5d4OrqWtPlY4zVgDt3KO2Dv3/pxK8hQ2ioZ0EBPef1fs1PtQKAWq1GYWEhOnbsCDc3N8j4U8OYwSouBi5fpsr+2jVKAWFlBUhZWxISKDDw9B3zo1Mn8Pfff4+QkBAoFAp4e3vDy8sLjo6OGDRoEPbs2VNbZWSMPYN79+jh7Q1s20bbQkOpCai4mDqDW7fm9X7NkVZ3AGq1GhMnTkRkZCR8fHwwbty4kvWAHz58iKNHj2LUqFGYNGkSNm/eXJvlZYzpQKWitn8LC1r45e+/AWtrYMwY2p+URIGB1/s1T1oFgC+++AI//PADPvroI7z55puQP5EhSq1WY926dZg9ezYGDRqE8ePH10phGWO6ka7+GzQA1q6lbYMHUxI4ab3frl2pc5iZH62agDZv3oxp06Zh9uzZ5Sp/AJDL5Zg5cyZef/11bNiwocYLyRjTnVpNa/zKZNQHEBtLV//Saq6pqRQImjTRbzmZ/mgVAGJjYzFkyJAqjxs0aBCuXbv2zIVijD27+/dp7H/Ztv+hQ2m2L0ABoFUrWvaRmSetAkBubq5WQzzd3d2RlJT0zIVijD0b6eofoD6AW7dootfo0bQtIwNwcipd/pGZJ60CgBACFloMEZDL5VCr1c9cKMbYs3nwgK7+vbxKr/7DwqjSB0rX+y2Tz5GZIa2HgfJYf8aMgxB09a9WU+bPu3cp+duIEbQ/N5f6AgID9VlKZgi0ngg2Y8YMOEmXD5XIysp65gIxxp7No0fAzZt09S+l5ho+HHB0pO/j42nWb/36+isjMwxaBYBevXpBJpOVLP5SGUdHR/SSkoswxvTi6lWa4BUTQ+kf7O1LUz5nZdGQz+ee4/V+mZYB4OjRo7VcDMZYTbl9G/D0LL36HzGidKTPo0dA+/Z89c8IXwMwZiKkG/TCQuD8eVr4xdERGDaMtqenUyBo146TvjHCAYAxEyGNwHZ3B77/nr4fNYo6gIUAEhMp54+Hh/7KyAwLBwDGTIQ0B/PcORkSEgBnZ0r5DNCkr3r1Slf/YgzgAMCYSUhMpJE/SqUMkZE0Z2f0aJr8pVYDKSlA27als4AZAzgAMGYSrl4F8vKAX3/1R1KSDPXqUdI3gJqGPDwo7QNjZXEAYMzIJSdT80+9esD//kezu8aMoeGeKhWQmUnDPqV5AIxJqrUiGGPMcFy9SrN7L1yQIzXVDm5uAgMH0jCfxERKBteihZ4LyQwS3wEwZsRSUujq38UF+OEH+nd+8UU1rK0BpRLIzqZx/3Z2+i0nM0x8B8CYEfv7b6rkr10D0tNl8PDIQ//+VgAs8OgRrfXLGT9ZZfgOgDEjlZZGAcDZGdixg7a9+GIsrKxoMlhhIRAURInfGKsIBwDGjNTff1MH78mT9NXLS6Bv3/sAKOFbo0a82hd7Og4AjBmhjAzq/HVwAHbupG3jxqlgaSlQUEBj/4OCAEtu5GVPwR8PxozQtWsUBC5fpj4AHx+gd29KBvToERAQQHcAjD0N3wEwZmQyM2nBF3t7YNcu2jZ+PCAt2mdhwememXb4DoAxI3P9OmX2/PNPICcH8PUFevYs3d+sGW1jrCp8jcCYEcnOpqt/W1tg717aNmECXfVLC/K1bs3pnpl2OAAwZkRiY2ny14kTNPu3YUOge3faJ6WD9vLSX/mYceEAwJiRyMkBLl2iHD/79tG2CROorT8trXTVL8a0xQGAMSMhXf0fPw7k5wONGwNdutBiL0lJtNA7Y7rQewAQQuC///0v2rVrBwcHBzRp0gSzZ89GltSgyRhDbi4N+ZTLgZ9+om0TJ9LzlBTA1ZXTPTPd6T0AfPjhh3jjjTcwdOhQ7N69G/PmzcPWrVsxatQoCGmRU8bM3M2bdJV//DhQUEDj/Dt1onTPKSk07NPJSd+lZMZGr8NA1Wo1Vq5ciWnTpmHlypUAgP79+8PNzQ1jx45FTEwMgoOD9VlExvQuPx+4eJG+P3iQvk6cSCN9kpKo05ebf1h16PUOICsrCy+//DJeeuklje3NmzcHANy6dUsfxWLMoNy8SXn9f/sNKCqi3P4dOgDFxTQprH17mhTGmK70egfg4uKCzz77rNz2nY+Tm7ThFayZmSsooKt/lQr4+Wfa9tJLdPWfkAA0aAA8vl5iTGcGNxP41KlTWLVqFUaMGIHWrVtXeExhYSEKCwtLnksdxkqlEkqlUuufJR2ry2uY7vg8V9+ff9LV/7FjciiVFmjVSo127VRQKqlpqGdPmgSmVPJ5rkuGfK51KZNMGFBP6/HjxzFs2DA0aNAAx48fh6ura4XHLV26FBEREeW2b9u2DQqForaLyVidSk62w4wZ/VFcLMfy5SfQpk2qvovEDFheXh5eeuklZGZmwqmKkQEGEwC2b9+OKVOmIDAwED///DO8vb0rPbaiOwA/Pz+kpKRU+QuXpVQqER0djQEDBsDKyuqZys8qx+dZd3l5wIEDNMJn/34LREXJ0a6dGv/6lwpFRcCDB8DgwZr5/vk81x1DPtdZWVlwd3fXKgAYRBPQhx9+iPfeew+9evXCnj174Ozs/NTjbWxsYGNjU267lZVVtf4Y1X0d0w2fZ+2o1cD580BcHA3tPHyYtr/0khwymRwPH1LFHxBQmgG0LD7PdccQz7Uu5dH7PID169dj3rx5ePHFFxEVFVVl5c+YqYuNpY5fPz9a6lGlopE+rVrRnQFA4/4rqvwZ04Ve7wASEhLw9ttvo2HDhpg1axbOnz+vsb9p06bw8PDQU+kYq3tpacDvvwN2dtT5e+QIbZdGSj98SGP+/fz0V0ZmOvQaAA4cOID8/Hzcu3cPPcsmNH9s06ZNmDJlSt0XjDE9KC4GTp+mdn9fXyAigpqDunUDAgMpFbSNDdCuHS/2wmqGXj9Gr776KoQQlT648mfm5PJlWui9YUPgiy9oaUcPD2DmTNofH0+BwMdHv+VkpoOvIxgzAPHxwNmzlNTt6FHK+WNhAbz7LuDoSOv/OjjQ1T8v9sJqCgcAxvSsoAA4dYomduXkABs30vZJkyjtgxDUH9CqFeDpqd+yMtPCAYAxPRICOHcOuH2bKvfVqynfT3AwMGIEHZOWBri4AG3b6rOkzBRxAGBMj+7coTH/Pj7Ahg00ysfNDZg9mzp61WrK+Nm2LVCvnr5Ly0wNBwDG9CQri5p+LCyo/f/oUar03323NLd/fDzdGfBiL6w2cABgTA/Uahrv/+gRfb9+PW2fOLG0sk9PpyRv3bpRRzBjNY0DAGN68PffwF9/0dX9hx9Su3/79sDo0bS/oABITgaefx5o1ky/ZWWmiwMAY3UsOZkmfDk6Alu2UM4fV1fg7bepCUilAu7eBVq3poVfeNgnqy0GkQyOMXNRVESVf1YWVfyHD1Ol/847NNIHoMq/YUOge3fAwPKMMRPDdwCM1aELF4Dr1wFLS+DLL2nb+PGlQzwfPaIJXz17crs/q30cABirI3FxNObfxQX46CNq52/XDnjxRdqflUWTwbp3B+rX12tRmZngAMBYHcjNpSGfxcWU4vnePQoE77xDw0ALC+nqPziYZv8yVhe4D4CxWiYE8McfVOknJgJRUdSx+847NLlLpaIJYa1aAZ06cacvqzt8B8BYLbtxg9r+LS2Bdeto29ixtKgLANy/DzRoAPToAVhb662YzAxxAGCsFqWn06gfuRz4/HNq42/Thjp+AbojsLEBevUCeDE8Vtc4ADBWS4qLabZvcjJw8CA18zg7l7b7Z2fTo3t3WgCGsbrGAYCxWvLXX8CVK5Tg7dAh2vb225TsragIePCAJnpxnh+mLxwAGKsFCQnAmTN0FyDl+Rkzhip8tZruBlq2BLp04eUdmf7wR4+xGiYt8JKVRYu75OdTZT9xIu2/fx/w9qZOXxsb/ZaVmTceBspYDRICiIkBbt4Ejh0Dbt2iGb1z51K7f3IyjQbq2ZPz+zP94zsAxmrQ3bvAn39Su/+BA7Rt9mxa3D0nh9b27dqVcv0wpm8cABirIRkZ1PSTkgJ89RVtGzmSJncpldTp2749pX9gzBBwExBjNeD2bar8HzwAtm6l1A+BgbSwuxDU6du0KXf6MsPCAYCxZ1BURGv6njtHKRxOn6b2fwcHWtrR0pI6fd3dgZAQwM5O3yVmrBQHAMaqKSWFrvqvX6dRPbGxwN69tO/NN2m1r9RUet6zJ43/Z8yQcABgTEdqNVX2p05RqocmTSgIfPIJ7R8+nJp68vIoSPTpQ8cwZmg4ADCmg7w84OxZSu5mZwf4+QGbNwP799P+5s2ByZNpAtj9+9TpGxSkxwIz9hQcABjT0sOHwMmTNNTTz48q+IgIyuMPAAMHAlOnUrv/zZtA48Y05NPCQq/FZqxSHAAYq0JxMXD5Ml355+fTGP7ISGD3bhrh4+YGzJpFaR4AGgnk4kIZPu3t9Vlyxp6OAwBjT5GZSSN7/voLcHWlyVxz51IlDwD9+gH/+AeN+gGoT0CpBPr3p05gxgwZBwDGKiGN7U9IAHx86Ir/xx+pE7hePWDmTKBz59Ljc3OBpCQa8RMQoLdiM6Y1DgCMPaGoiPL5nDtHk7YsLID336clHQEaz//PfwJOTvRcpaL+AaWSOnw7duRlHZlx4ADAWBkpKdTRGxtLk7eio4H//Y8qeWdnYMYMoFu30uPT0+kOwdeXUj40bcozfZnx4ADAGKhZ5/p1au/PyKCRPP/+N2XzBKjSnz6dOncBukuIi6N0zt2705U/d/gyY8MBgJm9vDxavOXCBarQL1wAvv+eRv84OADTptGIHpmMRv0kJlLncEAAXfU3aKDv34Cx6uEAwMxa2bH9cjnwn/9Q8w9AlfvMmTT6B6BO3gcP6HloKC3yYmWlt6Iz9sw4ADCzJI3tP3OG7gD+/hvYto2aduztgddeA/r2pav+sp287doBwcGlQYExY8YBgJmd1FSq+K9epUCwZQt9D1DqhlmzqAMYoE7exMTSTt4mTbiTl5kODgDMbKhUwLVrVPmnpFCn79atQGEh5fV59VVq2pHJaFtcHGBrS2v3PvccoFDo+zdgrGZxAGBmIT2dUjlcuUJt+Tt2AJcu0b62bSl9s5cXdfImJNCC7s2a0VV//fr6LTtjtYUDADNp0vDOM2foiv7sWeDgQbobsLGhzJ1DhlCzTk4OtfVLnbwtWnAnLzNtHACYycrMpIr/8mXg4kVarCUzk/Z16kQ5fHx8KBjcu0dfg4Kok1ca78+YKeMAwEyOWk3pmE+fLr3iv3OH9jVoQCN8Onak52lplL/H1xd4/nlK4cxpHFidEoLaJTMySh+ZmfS1Xz9abq6WcABgJiU7myr948eBn36ifD4ADe0cPx4YOpRm+RYUUJOQQkHJ2557jtfrZdVUXEzth1Kl/WQlLj3S0+nx5DHZ2XT7WZH//Q948cVaKzoHAGYShKC0Db/9Rrn6jx2jkTwyGTBgAPDyy9Ssk5dXmtRN6uStxQsspi8qFS3ekJ9Pf/TKvpeel/0qPXJzaVtubrnjLPPzMSQnB5ZKJU0QqQlyOV2R2NrSV3v7Wr8d5QDAjF5ODvDHH8C331I7f1oabW/VirJ2Nm1K/8O3btH/WEAA0KYNrerFq3XVArWaZtQVFVEUlr5q8/2T2woKNCvtspWxVEHn55ceV1BAj6KiWv0VZQDKjQ+wsqLbSOmhUJRW5A4OpV8dHelqxMODVhNyd6evDg6AtTW9j6Ulfa3lzigOAMxoCUFt+//7H7BhA+XvB+j/aepUGr+fmwvcuEH/S4GBQOvW1N7Pk7keKyqiCJqdTY+y3z/5/Ml9WVml30sVc01eEdcUqTK1ti6tYKXvpYeNDX21tdX8Xnpua0sVuKMj4OgIpZ0djuXmIiQgAFZSpa5Q0HuXrcDLfm+AnUscAJhRyssDfvkFWL2aFm0Rgv5nR40CRo+mC8gbN+j/tk0bqvh9fAzyf1A7SiVVsjk5lX6VZ2WhWUwM5GfOlF4h5+SUPqSKuuxra/lKGQBFW6kitLAorRCl76WHdEzZ76XKuexDqpRtbEorZXv70u8dHEqvuO3sSn+W9JAWeahom1yu3YdEqUTugQNA795GPVaYAwAzOjdvAsuX05V/fj5t69EDmDKF/hfv3qX//aAgqvi9vGqp4heCKuYn25efbFuu6HlF+6Sr6LJNG9J+LSpqCwCtqvu7WFpqXu2WfZRt0ijbtKFQUBOFszMtkSZdBUvt2NL7WVpSxVr2IZOV31bRQyYz4qht+DgAMKORnw+sXw+sWkWzdQEatvnaazS8MzmZ6qBOnYCWTYvgaZ9LlWlsmYq17ONpnYOVVehltxcUVD56o7ZYWJS/In78UNvaIs7JCb5yOSzs7Eo7E6UK3N6eljFzdCyttF1d6audXfkrcum5dGXMTI5BBIBDhw5h4cKFuHr1Kjw8PDB9+nTMnz8fMo78pksIaqd5slKWmieeeNz/OxfHD+XCNjEXq5ELZ8tcBNTPhatFLuSf58CmOBe26lxYFeVBnp9LQ/PqkkxGtx9S+3FFj4qaMp686pYqaqkZw8GBKmvpStveXrNiLvO9SghcOHQIPkOGwMKImyVY3dF7ADh16hSGDx+OcePGYfny5Thx4gQWLFgAtVqNBQsW6Lt45kcIam6Qrnar83ii8rbIyUHvR49gOWeOZjOHWq11sfwBTCy7oRhAnBYvfMoVs0bnX0X7n2xrLtvOXLa92cmJvpatlCtrZ65Nhtb5ygye3gNAREQEgoKCsGXLFgDAoEGDoFQq8cEHH2DOnDmwq83ZOUJoPmryfdXqmn2oVHTFLA1zKygo/7yibVUdU7bilobR6VAxa0MOwPkp+4vlViiQK5ALe+QIe2SqHZEtHJALe42HsxPQ0i8b1rZyWDrawcXbFvXq28LWzaG0acPJia6UpatmaWhd2YqYmzUYA6DnAFBYWIijR48iIiJCY/uYMWOwevVqHD9+HKGhobX28y369MELp07V2vsbPZmsfDNGRUPonmjiELa2yBaOSClyQlKhEx7kueDPHBfkZrvjTno93EmvhxSlU0nFrlJbAhXEHCcnGirt4QF06AA0bAiovCh7Z6NmVN8zxqpPrwHg9u3bKCoqQvPmzTW2BwQEAABiY2NrNQAYAiGNcpDJH3+v+VXI5CXfqy2sobK0hsrCGioLG6gsrFFsYYNiC2sUy21QLLeG0sIGSrnmo0hmiyK5DQphiyKZDQrltiiU2aJQrkCBhR0K5PYokCtQILdHvtwe+XIF8uX2KIAdVLCASshQrJJDpQZUahmKVTKoVDKoVNTUrspByfeFhZRRs7Cw6t/dwQHwedwPKfVFSv2SLi7UfymX0wW7kxNV/AEBvPg6YzVFrwEgIyMDAODk5KSx3fHxpV1WVlaFryssLERhmRpGOk6pVEKpQzvoZOc9OFcvH9ZySwjIoFY/br0paRV6vA2PW4iErKR1R+DxV2mb9BpQx7UKFlBDXvIQkGk8l7ZByOjNTIxMJh5X5gJubmr4+9+CvX0jeHpaoEEDgfr1qVK3tS29gahsSLilJVX61tb03tzUXTHps6/L/wCrHkM+17qUSa8BQP24rbmy0T7yStpoV65cWa7ZCACioqKg0GHZpgt3e+BGup/Wx9cUuVzAQi4gl6shl4sKHzRMmr63sJC+qmFhUfq8om30vVrr52Ufmu9b+bby36sfD9tWw9JSwNW1AG5u+bC0fDKyXdN4JnVDsJoVHR2t7yKYDUM813l5eVofq9cA4PI4z8WTV/rZ2dkAAGfnirsOw8PDMWfOnJLnWVlZ8PPzQ2hoaLm7iadp2LAYv/56FK6uz8PS0hIyGfUNVjRHpbJt0mue3F7RVWzZCYlPvp9MJoNcLiv33mW/N9ZRsUqlEtHR0RgwYACseHhireHzXHcM+VxX1nJSEb0GgKZNm8LCwgI3b97U2C49b9Wq4nmNNjY2sLGxKbfdyspKpz9G69bAvXuZGDLE0uD+iKZI178Pqx4+z3XHEM+1LuXR6zg4W1tb9OrVCzt37oQoMwxzx44dcHFxQefOnfVYOsYYM216nwewcOFC9O/fH2PHjsWrr76KU6dO4cMPP8SqVatqdw4AY4yZOb3PhOnbty9+/PFHXL9+HSNGjMDWrVvx4Ycf4t1339V30RhjzKTp/Q4AAEaOHImRI0fquxiMMWZW9H4HwBhjTD84ADDGmJniAMAYY2aKAwBjjJkpDgCMMWamOAAwxpiZ4gDAGGNmyiDmATwrKY2ELkmQAErolJeXh6ysLIPL52FK+DzXDT7PdceQz7VUDwotVjk0iQAgZQ/186v71M6MMWaIsrOzK82oLJEJbcKEgVOr1YiPj4ejo2OlawtUREojHRcXp1MaaaYbPs91g89z3THkcy2EQHZ2Nnx8fCpdU0ViEncAcrkcvr6+1X69k5OTwf0RTRGf57rB57nuGOq5rurKX8KdwIwxZqY4ADDGmJky6wBgY2ODJUuWVLi6GKs5fJ7rBp/numMq59okOoEZY4zpzqzvABhjzJxxAGCMMTNl0gHg0KFDCA4OhkKhQMOGDbFy5coqZ8d99913aN26Nezs7BAYGIiNGzfWUWmNm67n+tq1a5DJZOUeLVq0qMNSG6+4uDi4uLjg6NGjVR7Ln+nq0/Y8G+vn2STmAVTk1KlTGD58OMaNG4fly5fjxIkTWLBgAdRqNRYsWFDha3744Qe88soreOuttzBo0CDs3r0b//znP2FnZ4eJEyfW8W9gPKpzri9cuAAAOHLkCGxtbUu229nZ1UWRjdq9e/cwcOBAZGZmVnksf6arT5fzbLSfZ2GiQkNDRadOnTS2zZs3Tzg4OIi8vLwKX9O8eXPx4osvamwbO3asaNq0aa2V0xRU51y/9957olGjRnVRPJOhUqnE119/LVxdXYWrq6sAII4cOfLU1/BnWnfVOc/G+nk2ySagwsJCHD16FKNGjdLYPmbMGOTk5OD48ePlXnP37l3ExsZW+Jpbt24hNja2VstsrKpzrgG6YgoKCqqDEpqOS5cuYcaMGZg8eTK2bNlS5fH8ma4eXc8zYLyfZ5MMALdv30ZRURGaN2+usT0gIAAAKvzg//333wCg02tY9c41QP8wmZmZ6Nq1K2xtbeHt7Y358+dDqVTWepmNlb+/P27evImPPvoICoWiyuP5M109up5nwHg/zybZB5CRkQEA5XJ0ODo6Aqg4bXR1XsOqd94SExORmJgIuVyOVatWwd/fH4cPH8aqVasQFxeHrVu31nq5jZGrqytcXV21Pp4/09Wj63k25s+zSQYAtVoNAJVmBq0oQ15lrxGPR7JUlVXPXFXnXDs5OSE6OhqBgYElKbxDQkJgY2ODhQsXYuHChWjZsmXtFdpM8Ge6bhjz59kkPwEuLi4Ayl/hSOsGVJQpr7LX5OTkVPoaVr1zbWdnh/79+5dbv2Ho0KEAgIsXL9ZCSc0Pf6brhjF/nk0yADRt2hQWFha4efOmxnbpeatWrcq9JjAwUOMYbV7Dqneur1+/ji+//LJcxZSfnw8AcHd3r6XSmhf+TNcNY/48m2QAsLW1Ra9evbBz506NyUg7duyAi4sLOnfuXO41AQEBaNKkCXbs2KGxfceOHWjevDkaNmxY6+U2RtU51w8fPsSMGTPKnevIyEg4OjqiY8eOtV5uc8Cf6bph1J9n/Y5CrT2HDx8WMplMjBkzRhw4cEAsXLhQyGQysXr1aiGEEJmZmeL06dMiKSmp5DWbNm0SAMSMGTPEwYMHxYwZMwQAERkZqa9fwyjoeq6Li4tF7969hbOzs/j0009FVFSUeOutt4RMJhNr1qzR569iNI4cOVJufDp/pmueNufZmD/PJhsAhBBi586dom3btsLa2lo0btxY448h/WE3bdqk8Zovv/xSBAQECBsbG9GyZUvx7bff1nGpjZOu5zojI0PMnj1bNGrUSNjY2IhWrVqJ//73v3oouXGqqGLiz3TN0/Y8G+vnmdNBM8aYmTLJPgDGGGNV4wDAGGNmigMAY4yZKQ4AjDFmpjgAMMaYmeIAwBhjZooDAGOMmSkOAIzVIkOdZmOo5WJ1iwMA05vevXvD0tIS586dq3B/o0aNMGXKFJ3ec8qUKWjUqNGzF+4ZPXjwAGFhYbh3756+i6KhonJV5zwz08ABgOmVSqXClClTUFRUVCPvt2jRIuzatatG3utZ/PLLL/jpp5/0XYxyDLVcTD84ADC9cnZ2xpUrVxAREVEj79e0aVO0b9++Rt6LMVPHAYDpVVBQEF555RWsXr0aMTExTz1WpVLhiy++QNu2bWFnZwd/f3/Mnz8fBQUFJcc82QR0/vx59OvXD87OznB0dET//v1x5swZjfc9fvw4QkJCoFAo4OrqismTJyM5OfmpZbl9+zZeeOEFuLm5QaFQoGvXrjh48CAAYPPmzZg6dSoAoHHjxiXNK40aNcLbb7+Nfv36wcnJCdOnTwcApKWlYdq0afDy8oKtrS26dOmCw4cPa/w8mUyGL774Aq+99hpcXV3h4OCAMWPGIDExUeO4NWvWoEmTJrCzs0P37t2xb98+yGQyHD16tNJyAYBSqcS8efPg7e0Ne3t7hIaGlltHgJkg/eaiY+YsJCREhISEiPT0dOHj4yPatm0rCgsLS/Y3bNhQTJ48ueT5P/7xD2FpaSkWLFggoqKixKpVq4RCoRChoaFCrVYLIYSYPHmyaNiwoRCC0vZ6eHiIsWPHiqioKLF//37RpUsX4ezsLDIyMoQQQhw7dkxYWVmJQYMGiX379olvvvlG+Pv7i9atW4u8vLwKy61SqUTLli1F3759xU8//SSioqLE0KFDhaWlpbhx44ZISkoSCxcuFADEzp07xc2bN0t+H0tLSzF79mwRFRUlTpw4IfLz88Vzzz0nvLy8xIYNG8RPP/0kRo8eLSwtLcXhw4dLfiYA4ezsLKZMmSJ+/vlnsW7dOmFrayvGjx9fckxERISQy+XivffeEz///LN4++23hZ2dXUk2y6eVSy6Xi8GDB4tDhw6JTZs2CRcXF9GxY8dn/yMzg8YBgOmNFACEEGLv3r0CgFiwYEHJ/rIB4MqVKwKAWL58ucZ7bNmyRQAQBw4cEEJoBoDTp08LAOLEiRMlx9+8eVO8++674v79+0IIIbp16ybatGkjiouLS465fv26sLCwEJ9//nmF5X706JEAIL777ruSbRkZGeLtt98Wly9fFkKU5uG/c+eOxu/j7+8vVCpVybb//ve/AoD4/fffS7ap1WrRq1cvERwcXLINgOjRo4dGOaZOnSocHByEEELk5OQIOzs7MWvWLI1jpk2bppHOuLJy+fn5iaKiopJtCxYsEABEZmZmheeAmQZuAmIGYdiwYXj55ZexatUqnD9/vtz+Y8eOAQAmTpyosX38+PGwsLDAkSNHyr2mTZs28PDwwLBhwzBjxgzs27cP9evXx+rVq+Hn54e8vDz8/vvvGDp0KIQQKC4uRnFxMZo0aYKWLVsiOjq6wrJ6eXmhVatW+Oc//4kpU6YgMjISQgh89NFHaNOmzVN/z1atWmksxn748GF4e3ujY8eOJT9fpVJh2LBhOHfuHNLT00uO7dq1q8Z7+fr6Ijc3FwBw+vRp5Ofn48UXX9Q4ZsKECU8tj+T555+HlZVVyfMmTZoAADIyMrR6PTNOHACYwfj000/h7u5e4aigtLQ0AIC3t7fGdktLS7i7u1dYUTk4OOD48eMYOnQotm/fjuHDh8PDwwPTpk1DQUEB0tPToVarsWrVKlhZWWk8/vrrL8THx1dYTplMhujoaEyZMgWHDh3C+PHj4enpiXHjxpWUszJeXl4az1NTU5GQkFDu57/77rsAgEePHpUcq1AoNF4rl8tLxvNLfRaenp4axzx5vipjb29f7r0BQK1Wa/V6Zpws9V0AxiT16tXDl19+iREjRmD58uUa+1xdXQEACQkJGp28SqUSKSkplS68HRgYiC1btkClUuHs2bPYsmUL1q1bhyZNmuCNN96ATCbD22+/XeGV8pMVblk+Pj744osvsHbtWly8eBE7duzABx98AFdXV6xbt07r39nFxQXNmjXDtm3bKtzfuHFjrd7H19cXAJCUlFSyGLz0nLHK8B0AMygvvPACXnrpJaxcuVJjJE5ISAgAYOvWrRrHb9++HSqVCj169Cj3Xjt27ICHhwcSEhJgYWGBrl274osvvoCLiwvi4uLg6OiIDh064Nq1awgODi55tG7dGkuXLsXRo0crLOPp06fh5eWFP/74AzKZDEFBQVi+fDnatm2LuLg4AICFhYVWv29ISAji4uLg6empUYZffvkFq1evhqWldtdoQUFBcHZ2xs6dOzW2//jjjxrPtS0XMw98B8AMzmeffYbDhw9rDHFs1aoVJk+ejKVLlyI/Px+9e/fGhQsXsHTpUvTp0weDBg0q9z7du3eHSqXCiBEjMH/+fDg5OSEyMhKZmZkYPXo0AGDFihUYMmQIJk6ciIkTJ0KlUmHNmjU4c+YMFi5cWGH52rdvD4VCgUmTJmHp0qXw9vbGL7/8ggsXLuCtt94CQFf2ALBz504MGTIELVq0qPC9pk6dis8//xwDBgzA+++/D39/f0RHR2PVqlWYNWuWRrv80zg6OmLevHlYvHgxFAoFevfujWPHjpXcjUhNOtqWi5kJPXdCMzNWdhTQk3bu3CkAaAwDLS4uFsuXLxdNmjQRVlZWolGjRiI8PFzk5+eXHFN2FJAQQpw9e1aEhoYKV1dXYWtrK4KDg8XOnTs1ftYvv/wievbsKezs7ISzs7Po27evOH78+FPLHhsbK0aNGiU8PT2FtbW1aN26tVi/fn3J/uzsbNG/f39hbW0thgwZIoQoP6xVkpiYKF599VXh6ekpbGxsRGBgoFi9erXGaCEAYsmSJRqvW7JkiSj7L6xWq8W//vUv4evrK6ytrUXPnj3Fxx9/LACImJgYncpV0WghZnp4UXjGTEBxcTG2bduGPn36wM/Pr2T72rVr8eabbyI1NbXk6p8xCQcAxkxE69atYWNjg4ULF8Ld3R0XL17EokWLMHLkSGzatEnfxWMGiAMAYybizp07CA8Px5EjR5CRkQF/f39MmjQJ4eHhWvclMPPCAYAxxswUDwNljDEzxQGAMcbMFAcAxhgzUxwAGGPMTHEAYIwxM8UBgDHGzBQHAMYYM1McABhjzExxAGCMMTP1/wFrDySUUWVyJwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "plt.rcParams.update({'font.size': 12, 'font.family': 'Arial'})\n",
    "plt.figure(figsize=(4, 4))\n",
    "\n",
    "plt.plot(g_noise_stre, z_decode_psc_mean, label='Grid cells', color='blue')\n",
    "# plt.plot(g_noise_stre, z_decode_psc_gop_mean, label='PSC GOP', color='green')\n",
    "plt.fill_between(g_noise_stre, z_decode_psc_mean - z_decode_psc_std/30, z_decode_psc_mean + z_decode_psc_std/30, color='blue', alpha=0.3)\n",
    "\n",
    "plt.plot(p_noise_stre, z_decode_lsc_mean*10, label='Place cells', color='red')\n",
    "plt.fill_between(p_noise_stre, 10*z_decode_lsc_mean - 10*z_decode_lsc_std/30, 10*z_decode_lsc_mean + 10*z_decode_lsc_std/30, color='red', alpha=0.3)\n",
    "\n",
    "plt.xlabel('Noise strength')\n",
    "plt.ylabel('Decoding Error')\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('figures_cth/Bayesian_integration.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Simulation Loop for Rate Amplitude 10: 100%|██████████| 10000/10000 [00:48<00:00, 206.29it/s]\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm  # 用于显示进度条\n",
    "\n",
    "torch.manual_seed(1)\n",
    "exp_type = 'cth'\n",
    "save_path = os.path.join('./results/', exp_type)\n",
    "os.makedirs(save_path, exist_ok=True)\n",
    "\n",
    "### initialize LSC and PSC\n",
    "LSCModel = LSC(params_LSC).to(device)\n",
    "PSCModel = PSC(params_PSC).to(device)\n",
    "\n",
    "### stimulus and ground truth position\n",
    "pos_gt = torch.tensor(30., dtype=torch.float32)  # ground truth position\n",
    "pos_gt = pos_gt.to(device)\n",
    "phi_gt = position2phase_modules(pos_gt, params_PSC)\n",
    "\n",
    "pos_gt_np = pos_gt.detach().cpu().clone().numpy()\n",
    "phi_gt_np = phi_gt.detach().cpu().clone().numpy()\n",
    "\n",
    "# total_iterations = 5000\n",
    "# n_methods = 3\n",
    "num_simulation = 10000\n",
    "num_rate = 15\n",
    "rate_ampl = 10\n",
    "z_decode_psc = np.zeros(num_simulation)\n",
    "z_decode_psc_gop = np.zeros(int(num_simulation/50))\n",
    "z_decode_lsc = np.zeros(num_simulation)\n",
    "sigma_g0 = np.array(PSCModel.sigma_g)[0]\n",
    "sigma_p0 = np.array(LSCModel.sigma_p)\n",
    "pg_ratio = sigma_g0 / sigma_p0\n",
    "g_noise = np.array(PSCModel.sigma_g * rate_ampl)\n",
    "p_noise = np.array(LSCModel.sigma_p * rate_ampl * pg_ratio)\n",
    "phi_noise = np.array(PSCModel.sigma_phi * phi_ampl)\n",
    "\n",
    "for i in tqdm(range(num_simulation), desc=f'Simulation Loop for Rate Amplitude {rate_ampl}', leave=True):\n",
    "\n",
    "    phi_ampl = 5.0\n",
    "    activation_p = LSCModel.forward(pos_gt, noiseFlag=True, rate_ampl=rate_ampl)\n",
    "    activation_gs = PSCModel.forward(pos_gt, noiseFlag=True, rate_ampl=rate_ampl, phi_ampl=0.5)\n",
    "\n",
    "    ### PSC MAP decoding\n",
    "    z_est_MAP, phi_est_MAP = Simplified_PSC_MAP_decoder(PSCModel, activation_gs)\n",
    "    z_place_MAP = LSC_MAP_decoder(LSCModel, activation_p)\n",
    "    z_decode_psc[i] = z_est_MAP\n",
    "    z_decode_lsc[i] = z_place_MAP\n",
    "\n",
    "\n",
    "np.save(os.path.join(save_path, 'z_decode_psc_distribution.npy'), z_decode_psc)\n",
    "np.save(os.path.join(save_path, 'z_decode_lsc_distribution.npy'), z_decode_lsc)\n",
    "\n",
    "error_psc = z_decode_psc - 30\n",
    "error_lsc = z_decode_lsc - 30\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6NChWLhwoXYbQkRs+iaqJSGd8KQ+4YQnROdXVAQkJsrbsbHyfoimRq7XOOFJw6HVhCdh20dNRPULa9SN27333gudTgedTgej0Yg2bdpg8uTJ6kU3AGDlypXo0aMHzGYzYmNjccUVV2DSpEker2O32zF79mxceeWViI6ORrNmzdC7d28sXboU5eXlPt/7q6++Ut/b++d8p+HWF2F9HjUR1R8MZho8eLAaqN988w3uu+8+nD17FosWLcLatWsxcuRIzJw5E0OHDoVOp8PevXvxxRdfqM+32+244YYb8P333+Pvf/87evfujbi4OGzevBkvvvgiunTpgquuuqra99+/f3+V2qmveTSU94qMjKyyPNDLbAb6vBq54GzgJITgRTmILqSw0HVBjrg4IcrLQ12i+qk+X5Rj2LBhHsvuu+8+YbFYhBBCPProo6Jfv37nfY3nn39e6PV6sX379iqP2e12UVJS4vN569atEwDOe+EOpXwzZ84ULVq0EK1atRL5+fkCgFixYoXo27evMJlM4s033xQOh0M888wz4uKLLxaRkZHiyiuvFJ999pn6WtU9z5tWF+Vg0zcRacK9Rq1ENjVuUVFRanO1xWLBnj17sHv37mrXf/fddzFw4EB06dKlymNGo9HvS1Z6++KLL7Bv3z7k5OTgk08+UZdPmTIFEydOxL59+3DDDTfgpZdewpw5c/Diiy9i586duOGGGzB06FD89NNPHq/n/bzawqZvItIEz6OuHUIApaWhee/o6MBPtduyZQuWL1+OAQMGAAAmTJiAb775Bp06dUKrVq1w7bXXIiMjA3fddRdMJhMA4KeffkK/fv0CLm/Lli097l988cXYv3+/ej8mJgavv/662uR94MABAEBmZiZuu+02db0XX3wRU6ZMwciRIwHI6azXrVuH+fPn4+WXX1bX835ebWFQE5EmGM61o7QUaNo0NO9dUgL4U4n95JNP0LRpU1RUVKC8vBzDhg3DggULAMiQ/PTTT/HLL79g3bp12Lx5MyZNmoSXXnoJmzZtQnR09AWndr6Qb775BrGxsep9g9dl3Dp16uSzX7pbt27q7eLiYhw7dgy9e/f2WKd37974/vvvq31ebWJQE5Em2PRN/fv3x6JFi2A0GpGSkuJzcFXbtm3Rtm1b3HfffZg2bRrat2+PFStW4M9//jPat2+Pffv2Bfz+aWlpiI+P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Vq1EZGSkuPrqq9VTeBqKdevW+fx/HTNmjBBC1i6nT58uLBaLMJlM4rrrrhO7du0KbaGDVN13eOnSpeo6DW27//KXv6if44suukgMGDBADWkh6n57efUsIiKiMMZR30RERGGMQU1ERBTGGNRERERhjEFNREQUxhjUREREYYxBTUREFMYY1ERERGGMQU1ERBTGGNRERERhjEFNRFXce++9Pi/jOXjw4FAXjajR4WUuicinwYMHY+nSpR7LTCaTz3XLy8thNBovuKwmAn0eUUPFGjUR+WQymWCxWDx+EhISAAA6nQ6LFy/GsGHDEBMTg3/84x/IysrCVVddhTfffBNt2rSByWSCEAKHDh3CsGHD0LRpU8TFxWHEiBE4ceKE+j7VPY+IJAY1EQVk+vTpGDZsGHbt2oW//OUvAICff/4Z//nPf7By5Urk5eUBAIYPH45Tp05h/fr1yMnJwS+//II777zT47V8PY+IJDZ9E5FPn3zyCZo2beqxbMqUKXj66acBAKNGjVIDWmG32/H222/joosuAgDk5ORg586dyM/PR2pqKgDg7bffxhVXXIGtW7eie/fuPp9HRC4MaiLyqX///li0aJHHssTERPV2t27dqjynVatWHmG7b98+pKamqiENAB07dkR8fDz27dunBrX384jIhUFNRD7FxMTg0ksvPe/jF1omhIBOp6uynvdyX69FRBL7qImo1nTs2BGHDh3C4cOH1WV79+6F1WpFhw4dQlgyovqDNWoi8slms6GgoMBjmcFgQLNmzWr8GgMHDkTnzp1x1113Yf78+aioqMC4cePQt29fn03nRFQVa9RE5NPq1avRokULj58+ffr49Ro6nQ4ffPABEhIScN1112HgwIFo06YNVqxYUUulJmp4dIInLBIREYUt1qiJiIjCGIOaiIgojDGoiYiIwhiDmoiIKIwxqImIiMIYg5qIiCiMMaiJiIjCGIOaiIgojDGoiYiIwhiDmoiIKIwxqImIiMIYg5qIiCiM/T90EPwACvhi+wAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "# Load the data (assuming 'error_psc' and 'error_lsc' are provided)\n",
    "# error_psc = ...\n",
    "# error_lsc = ...\n",
    "\n",
    "# Compute the histogram for the PSC and LSC errors\n",
    "counts_psc, bin_edges_psc = np.histogram(error_psc, bins=500)\n",
    "counts_lsc, bin_edges_lsc = np.histogram(error_lsc*10, bins=500)\n",
    "\n",
    "# Calculate the bin centers\n",
    "bin_centers_psc = (bin_edges_psc[:-1] + bin_edges_psc[1:]) / 2\n",
    "bin_centers_lsc = (bin_edges_lsc[:-1] + bin_edges_lsc[1:]) / 2\n",
    "\n",
    "# Remove zero points\n",
    "nonzero_indices_lsc = counts_lsc > 0\n",
    "bin_centers_lsc = bin_centers_lsc[nonzero_indices_lsc]\n",
    "counts_lsc = counts_lsc[nonzero_indices_lsc]\n",
    "\n",
    "# Plot the histogram with non-zero points only\n",
    "plt.figure(figsize=(5, 4))\n",
    "plt.plot(bin_centers_lsc, counts_lsc, label='LSC Error', color='red')\n",
    "plt.plot(bin_centers_psc, counts_psc, label='PSC Error', color='blue')\n",
    "\n",
    "plt.fill_between(bin_centers_psc, counts_psc, color='blue', alpha=0.3)\n",
    "plt.fill_between(bin_centers_lsc, counts_lsc, color='red', alpha=0.3)\n",
    "\n",
    "plt.xlabel('Error')\n",
    "plt.ylabel('Counts')\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig('figures_cth/Non_local_error.pdf')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([0.0465, 0.0349, 0.0279], dtype=torch.float64)\n",
      "tensor([0.1637, 0.1637, 0.1637], dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(PSCModel.sigma_phi)\n",
    "print(PSCModel.sigma_g)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "# # save the results\n",
    "# z_est_arrays[pi_index,n_index,0] = z_est_GOP\n",
    "# z_est_arrays[pi_index,n_index,1] = z_est_MAP\n",
    "# z_est_arrays[pi_index,n_index,2] = z_est_LSC\n",
    "# print('z_est:', z_est_GOP, z_est_MAP, z_est_LSC)\n",
    "\n",
    "# for module in range(params_PSC['M']):\n",
    "#     phi_est_arrays[pi_index,n_index,0,module] = phi_est_GOP[module]\n",
    "#     phi_est_arrays[pi_index,n_index,1,module] = phi_est_MAP[module]\n",
    "#     phi_est_arrays[pi_index,n_index,2,module] = None\n",
    "\n",
    "# # save the results\n",
    "# np.save(os.path.join(save_path, 'z_est_arrays.npy'), z_est_arrays)\n",
    "# np.save(os.path.join(save_path, 'phi_est_arrays.npy'), phi_est_arrays)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# torch.manual_seed(1)\n",
    "# exp_type = 'cth'\n",
    "# save_path = os.path.join('./results/',  exp_type)\n",
    "# os.makedirs(save_path, exist_ok=True)\n",
    "\n",
    "# ### initialize LSC and PSC\n",
    "# LSCModel = LSC(params_LSC).to(device)\n",
    "# PSCModel = PSC(params_PSC).to(device)\n",
    "\n",
    "# ### stimulus and ground truth position\n",
    "# pos_gt = torch.tensor(30., dtype=torch.float32)  # ground truth position\n",
    "# pos_gt = pos_gt.to(device)\n",
    "# phi_gt = position2phase_modules(pos_gt, params_PSC)\n",
    "\n",
    "# pos_gt_np = pos_gt.detach().cpu().clone().numpy()\n",
    "# phi_gt_np = phi_gt.detach().cpu().clone().numpy()\n",
    "\n",
    "# rate_ampls = np.array([0.5, 1., 1.5, 2., 2.5, 3., 3.5, 4., 4.5, 5., 5.5, 6., 7., 8., 9., 10.])\n",
    "# num_simulation = 10\n",
    "# total_iterations = 5000\n",
    "# n_rate_ampls = len(rate_ampls)\n",
    "# n_methods = 3\n",
    "# z_est_arrays = np.zeros([n_rate_ampls, num_simulation, n_methods])\n",
    "# phi_est_arrays = np.zeros([n_rate_ampls, num_simulation, n_methods, params_PSC['M']])\n",
    "\n",
    "# for pi_index, rate_ampl in enumerate(rate_ampls):\n",
    "#     rate_ampl = float(rate_ampl)\n",
    "#     for n_index in range(num_simulation):\n",
    "#         print('Simulation trial:', n_index)\n",
    "#         ### generate observation\n",
    "#         activation_p = LSCModel.forward(pos_gt,noiseFlag=True,  rate_ampl=rate_ampl)\n",
    "#         activation_gs = PSCModel.forward(pos_gt, noiseFlag=True, rate_ampl=rate_ampl)\n",
    "\n",
    "#         ### PSC GOP decoding\n",
    "#         # z_t = pos_gt - params_prob[\"v\"] * params_prob[\"dt\"] # previous position\n",
    "#         z_t = pos_gt # previous position\n",
    "#         phi_t = position2phase_modules(z_t, params_PSC)\n",
    "#         z_ts, phi_ts = PSC_GOP_decoder(PSCModel, total_iterations, z_t, phi_t, activation_gs)\n",
    "#         z_ts = torch.stack(z_ts).detach().cpu().numpy() # shape [total_iterations+1, 1]\n",
    "#         phi_ts = torch.stack(phi_ts).detach().cpu().numpy() # shape [total_iterations+1, M]\n",
    "        \n",
    "#         z_est_GOP = z_ts[-1]\n",
    "#         phi_est_GOP = phi_ts[-1]\n",
    "#         # clear z_ts, phi_ts\n",
    "#         z_ts, phi_ts = [], []\n",
    "\n",
    "#         ### PSC MAP decoding\n",
    "#         z_est_MAP, phi_est_MAP = PSC_MAP_decoder(LSCModel, PSCModel, activation_gs)\n",
    "\n",
    "#         ### LSC MAP decoding\n",
    "#         z_est_LSC = LSC_MAP_decoder(LSCModel, activation_p)\n",
    "\n",
    "#         # save the results\n",
    "#         z_est_arrays[pi_index,n_index,0] = z_est_GOP\n",
    "#         z_est_arrays[pi_index,n_index,1] = z_est_MAP\n",
    "#         z_est_arrays[pi_index,n_index,2] = z_est_LSC\n",
    "#         print('z_est:', z_est_GOP, z_est_MAP, z_est_LSC)\n",
    "\n",
    "#         for module in range(params_PSC['M']):\n",
    "#             phi_est_arrays[pi_index,n_index,0,module] = phi_est_GOP[module]\n",
    "#             phi_est_arrays[pi_index,n_index,1,module] = phi_est_MAP[module]\n",
    "#             phi_est_arrays[pi_index,n_index,2,module] = None\n",
    "\n",
    "# # save the results\n",
    "# np.save(os.path.join(save_path, 'z_est_arrays.npy'), z_est_arrays)\n",
    "# np.save(os.path.join(save_path, 'phi_est_arrays.npy'), phi_est_arrays)"
   ]
  }
 ],
 "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
}
