{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "e1c85365-80fd-4616-9b4c-a05bf79a85a6",
   "metadata": {},
   "source": [
    "# 24th September - Motor Pot/Prep Networks - Single Reaches\n",
    "\n",
    "This notebook trains networks on single reach tasks, then studies how aligned the preparatory and potent subspaces are. \n",
    "\n",
    "The data is constructed to contain all combinations of the following parameters.\n",
    "1. Prep_periods, how long before the first movement is the cue provided.\n",
    "4. Num_reaches says how many different reaches to have, one-hot coded"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "90fd0848-2e9b-4fa6-b858-2f4a35f8df31",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import jax.numpy as jnp\n",
    "import matplotlib.pyplot as plt\n",
    "from jax import vmap, value_and_grad, grad, jit, random\n",
    "import jax.nn as jnn\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "import math\n",
    "import optax\n",
    "import scipy\n",
    "import jax\n",
    "\n",
    "def get_PCs(vecs, num_eigs = 2):\n",
    "    vecs = vecs - np.mean(vecs, axis = 1)[:,None]\n",
    "    covar = vecs@vecs.T\n",
    "    eigvals, eigvecs = np.linalg.eig(covar)\n",
    "    \n",
    "    ordering = np.argsort(eigvals)[::-1]\n",
    "    #print(f\"Propotion of Activity Kept: {np.sum(eigvals[ordering[:2]])/np.sum(eigvals)}\")\n",
    "    return np.real(eigvecs[:,ordering[:num_eigs]]), np.real(eigvals[ordering[:num_eigs]])\n",
    "\n",
    "def plot_var(vecs, PCs):\n",
    "    demeaned_act = vecs - np.mean(vecs, axis = 1)[:,None]\n",
    "    total_var = np.sum(np.power(demeaned_act, 2))\n",
    "    PC_var = np.sum(np.power(PCs.T@demeaned_act, 2), axis = 1)/total_var\n",
    "    plt.plot(PC_var)\n",
    "    return np.sum(PC_var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "id": "9ffbcc18-1a5c-4f77-9b8e-b0afbbe25626",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x281334290>"
      ]
     },
     "execution_count": 178,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "prep_periods = [1, 3, 5]\n",
    "num_reaches = 2\n",
    "action_len = 2\n",
    "T = max(prep_periods) + action_len\n",
    "num_trials = num_reaches*len(prep_periods)\n",
    "\n",
    "def generate_data():    \n",
    "    outputs = jnp.zeros([num_reaches,num_trials,T])\n",
    "    inputs = jnp.zeros([num_reaches+1,num_trials,T])\n",
    "    for prep_ind, prep_period in enumerate(prep_periods):\n",
    "        for reach in range(num_reaches):\n",
    "            trial_ind = num_reaches*prep_ind + reach\n",
    "            outputs = outputs.at[reach,trial_ind,prep_period:prep_period+action_len].set(1)\n",
    "            inputs = inputs.at[reach,trial_ind,:prep_period].set(1)\n",
    "            inputs = inputs.at[num_reaches,trial_ind,prep_period-1].set(1)\n",
    "    return inputs, outputs\n",
    "\n",
    "inputs, outputs = generate_data()\n",
    "\n",
    "plot_trial = 100\n",
    "plt.subplot(1,2,1)\n",
    "plt.imshow(inputs[:,plot_trial,:])\n",
    "\n",
    "plt.subplot(1,2,2)\n",
    "plt.imshow(outputs[:,plot_trial,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "id": "10074609-be07-4447-8539-d732f4238c3c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define initialising functions, and losses\n",
    "N = 10 # Number of neurons\n",
    "I_Size = num_reaches+1\n",
    "O_Size = num_reaches\n",
    "\n",
    "# Initialise W orthogonal, and others random\n",
    "def initialise_weights(N, random_seed, init_scale = 0.01):\n",
    "    W = jnp.zeros([N, N+1])\n",
    "    key = random.PRNGKey(random_seed)\n",
    "\n",
    "    W = W.at[:,-1].set(random.normal(key, (N,))*init_scale)\n",
    "    Wp = random.normal(key, (N,N))\n",
    "    Wp, S, V = jnp.linalg.svd(Wp)\n",
    "    W = W.at[:,:N].set(Wp)\n",
    "\n",
    "    R = random.normal(key, (O_Size, N+1))*init_scale\n",
    "    I = random.normal(key, (N, I_Size+1))*init_scale\n",
    "    params = {'W':W, 'R':R, 'I':I}\n",
    "    \n",
    "    return params\n",
    "\n",
    "@jit\n",
    "def generate_rep(params, inputs, random_seed):\n",
    "    # Neurons by time points by trials\n",
    "    g = jnp.zeros([N, T, num_trials])\n",
    "    g = g.at[:,0,:].set(jnn.relu(params['I'][:,:-1]@inputs[:,:,0] + params['I'][:,-1][:,None]))\n",
    "\n",
    "    # For rest we just recurrently go around.\n",
    "    key = random.PRNGKey(random_seed)\n",
    "    subkey, key = random.split(key)\n",
    "    for t in range(1,T):\n",
    "        input_current = params['W'][:,:-1]@g[:,t-1,:] + params['W'][:,-1][:,None] +params['I'][:,:-1]@inputs[:,:,t] + params['I'][:,-1][:,None] \n",
    "        g = g.at[:,t,:].set(jnn.relu(input_current))\n",
    "    return g\n",
    "\n",
    "@jit\n",
    "def loss_weight(W):\n",
    "    return jnp.sum(jnp.power(W[:,:-1], 2))\n",
    "\n",
    "@jit\n",
    "def loss_act(g):\n",
    "    return jnp.mean(jnp.sum(jnp.power(g, 2), 0))\n",
    "\n",
    "@jit\n",
    "def loss_fit(g, R, outputs):\n",
    "    preds = jnp.einsum('ij, jkl -> ilk', R[:,:-1], g) + R[:,-1][:,None,None]\n",
    "    return jnp.mean(jnp.sum(jnp.power(outputs - preds, 2), 0))\n",
    "\n",
    "@jit\n",
    "def generate_pred(params, g):\n",
    "    preds = jnp.einsum('ij, jkl -> ilk', params['R'][:,:-1], g) + params['R'][:,-1][:,None,None]\n",
    "    return preds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "id": "c07aab34-a8be-4199-9ed3-2ef87700d17d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x2811ba310>"
      ]
     },
     "execution_count": 180,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "params = initialise_weights(N, random_seed)\n",
    "g = generate_rep(params, inputs, random_seed)\n",
    "\n",
    "plt.imshow(g[6,:,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 217,
   "id": "deafe116-ceab-4e43-8d75-8e74bf931dc9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8.307712\n"
     ]
    }
   ],
   "source": [
    "mu_fit = 10000\n",
    "mu_G = 1\n",
    "mu_W = 1\n",
    "fit_thresh = 0\n",
    "\n",
    "@jit\n",
    "def loss(params, inputs, outputs, random_seed):\n",
    "    g = generate_rep(params, inputs, random_seed)\n",
    "    \n",
    "    fitting_loss = loss_fit(g, params['R'], outputs)  \n",
    "\n",
    "    weight_loss = loss_weight(params['W'])\n",
    "    weight_loss += loss_weight(params['R'])\n",
    "    weight_loss += loss_weight(params['I'])\n",
    "    \n",
    "    return mu_fit*jnn.relu(fitting_loss-fit_thresh) + mu_G*loss_act(g) + mu_W*weight_loss\n",
    "\n",
    "@jit\n",
    "def update(params, inputs, outputs, opt_state, random_seed):\n",
    "    \"\"\" Compute the gradient for a batch and update the parameters \"\"\"\n",
    "    value, grads = value_and_grad(loss)(params, inputs, outputs, random_seed)\n",
    "    updates, opt_state = optimizer.update(grads, opt_state)\n",
    "    params = optax.apply_updates(params, updates)\n",
    "    return params, opt_state, value\n",
    "\n",
    "N = 10\n",
    "random_seed = 321\n",
    "learning_rate = 1e-5 #2e-5\n",
    "scale = 0.1\n",
    "key = random.PRNGKey(random_seed)\n",
    "noise_scale = 1\n",
    "\n",
    "re_init = False\n",
    "if re_init:\n",
    "    optimizer = optax.adam(learning_rate)\n",
    "    params = initialise_weights(N, random_seed, init_scale = scale)\n",
    "    opt_state = optimizer.init(params)\n",
    "    min_loss = np.infty\n",
    "else:\n",
    "    optimizer = optax.adam(learning_rate)\n",
    "    opt_state = optimizer.init(params)\n",
    "print(loss(params, inputs, outputs, random_seed))\n",
    "min_loss = np.infty\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 218,
   "id": "f5f17eac-219d-404c-b739-0ed093a008ee",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Step 0, Loss: 8.30771, Fit: 0.00000, Act: 0.71241, Wei: 3.36920, R: 2.46610, I: 1.75362\n",
      "New min! 8.307711601257324\n",
      "Step 10000, Loss: 8.30770, Fit: 0.00000, Act: 0.71246, Wei: 3.36923, R: 2.46608, I: 1.75363\n",
      "Step 20000, Loss: 8.30771, Fit: 0.00000, Act: 0.71246, Wei: 3.36925, R: 2.46609, I: 1.75364\n",
      "Step 30000, Loss: 8.30771, Fit: 0.00000, Act: 0.71246, Wei: 3.36925, R: 2.46609, I: 1.75364\n",
      "Step 40000, Loss: 8.30771, Fit: 0.00000, Act: 0.71245, Wei: 3.36927, R: 2.46611, I: 1.75365\n",
      "Step 50000, Loss: 8.30771, Fit: 0.00000, Act: 0.71246, Wei: 3.36927, R: 2.46610, I: 1.75365\n",
      "Step 60000, Loss: 8.30771, Fit: 0.00000, Act: 0.71246, Wei: 3.36925, R: 2.46608, I: 1.75366\n",
      "Step 70000, Loss: 8.30771, Fit: 0.00000, Act: 0.71246, Wei: 3.36927, R: 2.46611, I: 1.75367\n",
      "Step 80000, Loss: 8.30771, Fit: 0.00000, Act: 0.71245, Wei: 3.36928, R: 2.46613, I: 1.75367\n",
      "Step 90000, Loss: 8.30771, Fit: 0.00000, Act: 0.71246, Wei: 3.36923, R: 2.46609, I: 1.75367\n",
      "Step 100000, Loss: 8.30771, Fit: 0.00000, Act: 0.71245, Wei: 3.36924, R: 2.46610, I: 1.75367\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[218], line 6\u001b[0m\n\u001b[1;32m      3\u001b[0m noise_scale \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0\u001b[39m\n\u001b[1;32m      5\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m step \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(num_timesteps):\n\u001b[0;32m----> 6\u001b[0m     params, opt_state, loss_val \u001b[38;5;241m=\u001b[39m update(params,  inputs, outputs, opt_state, random_seed)\n\u001b[1;32m      9\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m step \u001b[38;5;241m%\u001b[39m print_iter \u001b[38;5;241m==\u001b[39m \u001b[38;5;241m0\u001b[39m:\n\u001b[1;32m     10\u001b[0m         g \u001b[38;5;241m=\u001b[39m generate_rep(params, inputs, random_seed)\n",
      "File \u001b[0;32m<string>:1\u001b[0m, in \u001b[0;36m<lambda>\u001b[0;34m(_cls, count, mu, nu)\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "num_timesteps = 10000000\n",
    "print_iter = 10000\n",
    "noise_scale = 0\n",
    "\n",
    "for step in range(num_timesteps):\n",
    "    params, opt_state, loss_val = update(params,  inputs, outputs, opt_state, random_seed)\n",
    "\n",
    "\n",
    "    if step % print_iter == 0:\n",
    "        g = generate_rep(params, inputs, random_seed)\n",
    "            \n",
    "        fitting_loss = loss_fit(g, params['R'], outputs)  \n",
    "    \n",
    "        weight_loss_W = loss_weight(params['W'])\n",
    "        weight_loss_R = loss_weight(params['R'])\n",
    "        weight_loss_I = loss_weight(params['I'])\n",
    "\n",
    "        L_a = loss_act(g)\n",
    "\n",
    "        loss_comp = mu_fit*jnn.relu(fitting_loss-fit_thresh) + mu_G*L_a + mu_W*(weight_loss_R + weight_loss_I + weight_loss_W)\n",
    "        print(f\"Step {step}, Loss: {loss_val:.5f}, Fit: {fitting_loss:.5f}, Act: {L_a:.5f}, Wei: {weight_loss_W:.5f}, R: {weight_loss_R:.5f}, I: {weight_loss_I:.5f}\")\n",
    "\n",
    "        min_this_step = 0\n",
    "\n",
    "    if loss_val < min_loss:\n",
    "        params_best = params\n",
    "        min_loss = loss_val\n",
    "        if min_this_step == 0:\n",
    "            print(f'New min! {loss_val}')\n",
    "            min_this_step = 1\n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 219,
   "id": "15c10288-94be-4c95-b2e4-8261affd174f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8.307696\n"
     ]
    }
   ],
   "source": [
    "print(min_loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 220,
   "id": "271d3478-9f2d-411c-80d0-0ca288abb194",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 2000x1000 with 18 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "g = generate_rep(params_best, inputs, random_seed)\n",
    "preds = generate_pred(params_best, g)\n",
    "\n",
    "plt.figure(figsize = (20, 10))\n",
    "for ang in range(num_trials):\n",
    "    plt.subplot(num_trials, 3, ang*3 + 1)\n",
    "    plt.imshow(inputs[:,ang,:])\n",
    "    \n",
    "    plt.subplot(num_trials, 3, ang*3 +2)\n",
    "    plt.imshow(outputs[:,ang,:])\n",
    "\n",
    "    plt.subplot(num_trials, 3, ang*3 + 3)\n",
    "    plt.imshow(preds[:,ang,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 221,
   "id": "a4aebb78-f6b5-4c75-96e2-b7842dc74bb1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABioAAAIkCAYAAACA43NBAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABqzUlEQVR4nO3de5zUdb348fewC7uAgCCKIguSiKaIF/CCqWgqamRqqdlJI6+paHjs4vUcNCV6WNrFElMRNUk95CXrFEoKmCKKKCfFc8xSf1KCCBkgyirw+f3hYQ/r7rI7C7vfYb/P5+Mxj9rZ7zDvHfTld3gzM4WUUgoAAAAAAIAMtMt6AAAAAAAAIL8sKgAAAAAAgMxYVAAAAAAAAJmxqAAAAAAAADJjUQEAAAAAAGTGogIAAAAAAMiMRQUAAAAAAJAZiwoAAAAAACAzFhUAAAAAAEBmLCoycPvtt0ehUIhCoRAzZsyo8/2UUgwYMCAKhUIccsghrT7fhvzhD3+IYcOGRadOnaJnz57x1a9+NRYvXtyk2955551x8sknx8477xzt2rWLHXbYod7jVqxYEd/+9rdjxIgRsfXWW0ehUIgrr7xyk8x/ww03xC677BIVFRXRv3//uOqqq+LDDz9s0m0//PDDuOqqq2KHHXaIioqK2GWXXeKGG26o99iUUkyaNCn23Xff6Ny5c3Tt2jX23nvv+PWvf71Jfg7YXOW1f8uXL4/LL788Bg4cGJ06dYrtt98+TjzxxJg/f36t4x577LE4/fTTY5dddonOnTvH9ttvH8cee2zMnTt3o+dvjf7deuutcdxxx8UOO+wQHTt2jAEDBsS5554bCxcu3Oj5oS3IawN32GGHmp97/cs555yzwdvdeuutUSgUYostttjo+ZvbwNdff73e2QuFQtxzzz11jncOCA3LYwNnzJjRYEMa6uATTzwRn/nMZ6J79+7RsWPH2GmnneLqq6/eqPlb4zzwyiuvrPdnrKys3KjZoa3IYwMjmn4eOG/evBg5cmT07ds3OnbsGD169Ihhw4bFXXfdtdHzt0YD77777jj44IOjV69eUVFREb17945jjjkmZs2atdHz50l51gPkWZcuXWLixIl1AjRz5sz461//Gl26dMlmsAbMnDkzjj766Bg5cmT8+te/jsWLF8fFF18chx12WDz77LNRUVGxwdv/4he/iEWLFsW+++4ba9eubTAKS5cujZtvvjn22GOPOO644+LWW2/dJPOPGzcu/u3f/i0uueSSGDFiRMyZMyeuuOKK+Pvf/x4333xzo7c/77zz4he/+EVcffXVsc8++8TDDz8cY8aMiRUrVsRll11W69hzzz03br/99vjXf/3XGD9+fKxevTpeeOGFeO+99zbJzwKbu7z175hjjolnn302rrzyyhg6dGj87W9/i+985zsxbNiweOGFF6Jfv34RETFhwoRYunRpjBkzJnbdddd4++2347rrrov9998/Hn744fj0pz/drPlbq39jx46NQw89NL773e/G9ttvHy+//HJcffXV8etf/zqef/756NWrV7Pmh7Ymbw2MiPjUpz4VP/jBD2pdt6Em/P3vf49vfvOb0bt371i2bNlGzb+xDYyIuOCCC+Jf/uVfal2300471TnOOSA0Lk8N3HvvveOpp56qc/2ECRPizjvvjOOPP77W9b/85S/j1FNPjZNOOinuvPPO2GKLLeKvf/1rvPnmm82evzWfB0dETJ06Nbp161bzdbt2/n4srC9PDVynKeeB//znP6Oqqiq+9KUvxfbbbx8rV66MyZMnx6mnnhqvv/56XHHFFc2av7UauHTp0vjUpz4VY8aMiZ49e8bChQvj+uuvj4MPPjgeffTRGD58eLPmz51Eq5s0aVKKiHTmmWemjh07pmXLltX6/imnnJKGDRuWdttttzR8+PBshqzHPvvsk3bdddf04Ycf1lz35JNPpohIN954Y6O3X7NmTc3/HzlyZOrXr1+9x61duzatXbs2pZTS22+/nSIijR07dqNmX7JkSaqsrExnn312revHjRuXCoVCmj9//gZv/+KLL6ZCoZC++93v1rr+rLPOSh07dkxLly6tue6BBx5IEZHuvffejZoZ2qI89u+VV15JEZGuuOKKWtfPmjUrRUS6/vrra65766236tx+xYoVqVevXumwww5r1uyt2b/65p8zZ06KiHT11Vc3a35oS/LYwJRS6tevXxo5cmRR9/nZz342HXPMMWnUqFGpc+fORc+8zsY28LXXXksRkb7//e83el/OAWHD8trAj1u7dm36xCc+kfr161frOfLf/va31Llz53TuuedukrlTat3zwLFjx6aISG+//fYmmx/akrw2sDnngevbb7/9UlVVVbNu25oNrM8///nP1L59+3Tqqac2a/48strO0Je+9KWI+OjlQessW7Ys7rvvvjj99NPrvc1VV10V++23X/To0aPmpeQTJ06MlFLNMU888US0b98+vvnNb9a67bqXmU2cOLHoWf/+97/HnDlz4tRTT43y8v97Ic4BBxwQAwcOjAceeKDRX6Opf5Ni3cvANqWpU6fGqlWr4rTTTqt1/WmnnRYppXjwwQc3ePsHH3wwUkr13v7999+PqVOn1lz34x//OHbYYYc46aSTNtn80NbkqX/t27ePiKj1N8siIrbccsuIiFovh99mm23q3H6LLbaIXXfdNRYsWFD07BGt27/65h8yZEiUlZU1e35oi/LUwOa46667YubMmXHjjTdu9K+1sQ0shnNAaJq8N3D69Onx6quvxmmnnVbrOfKtt94aK1eujIsvvrjoX7MhrXkeCDRN3htYrJ49e9a672Jk3cAuXbpEZWVls+fPI4uKDHXt2jVOOOGEuO2222quu/vuu6Ndu3bxxS9+sd7bvP766/G1r30t/uM//iPuv//++PznPx8XXHBBrfesPPDAA+Oaa66J6667Lh566KGIiJg/f36MHj06TjnllDjjjDNqjl33PpL1vT/e+l588cWIiBg8eHCd7w0ePLjm+6Vq3Xy77757reu322676NmzZ6Pzv/jii7H11lvHtttuW+v6dY/HutuvXr06nnrqqdhrr73i+uuvj379+kVZWVl84hOfiB/84Ae1/iMCeZan/vXr1y+OPfbY+OEPfxjTp0+Pd999N/7nf/4nvv71r0ffvn3j5JNP3uDtly1bFs8991zstttuGzyusflbun8NmTlzZqxZs6bZ80NblKcGrvP4449Hly5don379rHrrrvGddddF2vWrKlz3OLFi+PCCy+M733ve9GnT58m/dobsrENXOd73/tedOjQITp16hQHHnhgzeO7jnNAaLo8NnB9EydOjHbt2tX5g6/HH388evToEf/zP/8Te+65Z5SXl8c222wT55xzTixfvrzo+1l//tY8D9x9992jrKwsevXqFV/5ylfijTfeaNbs0FblsYFNPQ+MiFi7dm2sXr063n777bjxxhvj4YcfbvYCN4sGrlmzJj788MN4/fXX49xzz42UUowePbpZ8+eRlU7GTj/99Dj00ENj/vz5sdtuu8Vtt90WJ554YoPvSTdp0qSa/7927do45JBDIqUUP/7xj+Pf/u3fal6J8O1vfzsef/zxGDVqVDzxxBNx0kknRd++feOmm26q9eu1a9cuysrKGn0Fw9KlSyMiokePHnW+16NHj5rvl6qlS5dGRUVFdO7cuc73mjL/0qVL6/3ZO3fuHB06dKi5/ZIlS6K6ujoeffTRmDNnTowbNy769OkTU6ZMiW9961vxzjvvxLhx4zbNDwWbuTz1b8qUKTF69OhanzExePDgmDlzZnTv3n2Dtx09enSsXLkyLr/88kbvpz6t1b/6rFixIs4777yoqqpq8G8HQV7lqYEjR46MoUOHxo477hjvvPNOTJkyJb75zW/GvHnz4he/+EWtY88777zYeeed49xzz230122KjW1gRUVFnHXWWXHEEUfEdtttF2+88UbccMMNceyxx8Ytt9wSZ555ZkQ4B4Ri5amB6/vnP/8Z999/fxxxxBHRt2/fWt/7+9//Hu+9916ceOKJcemll8aPfvSjmDNnTowdOzZefPHF+OMf/1j0Ow+05nngjjvuGOPGjYu99torKisr45lnnolrr702HnnkkZg7d25sv/32Rc0ObVmeGljMeWDER+eCP//5zyMiokOHDvGTn/wkvva1rzV6Pw3N39rPhXfbbbd4+eWXI+KjhcjUqVNjyJAhzZo/jywqMjZ8+PDYcccd47bbbouvfvWrMWfOnLjuuusaPP6xxx6L7373uzFnzpw6f6ti8eLFNR9GUygU4s4774y99torhg4dGoVCIZ5++uk6/3L++7//e/z7v/97k+dtKGKb+q2aWsKGZmzK/E25/dq1ayMiYvny5fHwww/H/vvvHxERn/70p2PRokVx/fXXx6WXXhpbbLFFMaNDm5Sn/p177rnxwAMPxA9/+MPYe++9Y9GiRfH9738/Pv3pT8f06dNrPkz74/7t3/4tJk+eHDfccMNGndy0Rv8+btWqVfH5z38+/t//+3/x2GOP6R58TJ4a+LOf/azW18cee2x07949fvrTn8ZFF10Ue+21V0RE3HffffGb3/wmnn/++U16brkxDdxuu+3qfNDiiSeeGPvtt19ccskl8dWvfjXKy8udA0KR8tTA9U2ePDlWrVpVs+Rc39q1a2PVqlUxduzYuOSSSyIi4pBDDokOHTrEhRdeGI8++mgcfvjhRd1fYzNuyvPAU089tdb3Dj300Dj00ENj2LBhce2118aPf/zjJkwL+ZCnBjb1PHCdyy67LM4888xYvHhx/OY3v4nzzz8/Vq5cWectrTZ29qbOX+zt77vvvli5cmW88cYbcdNNN8XRRx8dDz30UJ0PT6d+3vopY4VCIU477bS466674qabboqBAwfGQQcdVO+xzzzzTIwYMSIiIm655ZZ48sknY86cOTV/y/b999+vdfxWW20Vn/vc52LVqlVx1FFH1XmpUzG22mqriIh6t4X/+Mc/6t0wlpKtttoqVq1aFe+9916d7zVl/q222qren33lypXxwQcf1Ny+e/fuUSgUomvXrjVPUNc5+uijY9WqVfHSSy9txE8CbUde+jd16tSYOHFi/PznP48LL7wwDj744DjppJNi2rRp8Y9//COuvPLKem931VVXxTXXXBPjxo2L888/f6Pmb43+ra+6ujqOP/74eOKJJ+Khhx6K/fbbr9nzQ1uVlwY25JRTTomIiNmzZ0dExLvvvhujR4+OCy64IHr37h3//Oc/45///Gd88MEHEfHR30JeuXJls+bfmAbWp3379vHFL34xli5dGq+88kpEOAeEYuW1gRMnToytt946jj322Abv68gjj6x1/dFHHx0REc8991xR97Xu12zt88D17bvvvjFw4MCa1gMfyWsD1/n4eeD6+vbtG0OHDo3PfOYzMWHChDj77LPj0ksvjbfffrvo+8migbvttlvsu+++ccIJJ8TUqVOjX79+MWbMmKJnzyuLihLw1a9+NZYsWRI33XRTnfepXN8999wT7du3j9/+9rdx0kknxQEHHBBDhw5t8Php06bFhAkTYt99940HHngg7rvvvmbPOGjQoIiIeOGFF+p874UXXqj5fqlaF+aPz79o0aJYsmRJo/Pvvvvu8fbbb8eiRYtqXb/u11t3+44dO8ZOO+1U76+x7r2Jm/qh4pAHeejfvHnzIiJin332qXX9lltuGQMGDKj3fS2vuuqquPLKK+PKK6+Myy67rJmTf6S1+rdOdXV1HHfccTF9+vR48MEH47DDDtuo+aEty0MDG/Lx86IlS5bEW2+9Fdddd11079695nL33XfHypUro3v37vHlL3+56PvZ2AY2dX7ngFC8vDXw+eefj+effz6+8pWvRPv27et8v773gI/YuIa09nlgfVJK+gf1yFsD11dM1/bdd99YvXp1vPrqq0XfT9YNLC8vj7333jv+/Oc/Fzt6bvmvRQnYfvvt41vf+lYcc8wxMWrUqAaPKxQKUV5eHmVlZTXXvf/++/W+p9vChQvjlFNOieHDh8esWbPic5/7XJxxxhnx2muvNXvGfffdN+66665aH3gze/bsePnll+Pzn/98s37d1nLUUUdFZWVl3H777bWuv/3226NQKMRxxx23wdsfe+yxUSgU4o477qhz+44dO8ZRRx1Vc90XvvCFWL58ecyaNavWsb/73e9iiy228IGysJ489K937941x69v6dKl8ec//7nOh8VeffXVceWVV8YVV1wRY8eObdbM62vN/q17JcVjjz0W9913X52/EQjUlocGNuTOO++MiKh59cG2224b06dPr3M58sgjo7KyMqZPnx7XXHNN0fezsQ2sz4cffhj33ntv9OzZMwYMGFBzvXNAKE7eGjhx4sSIiFofaLu+L3zhCxER8fvf/77W9b/73e8iIuq8WqspWvM8sD6zZ8+OV155pVmzQ1uXtwau7+PngRsyffr0aNeuXXziE58o+n6ybuCqVati9uzZtc4XaUSi1U2aNClFRJozZ84Gj9ttt93S8OHDa75+9NFHU0SkE044IT3yyCPp7rvvTkOGDEk77bRTioj02muvpZRSWr16dRo+fHjq1atXWrhwYUoppX/84x+pb9++aZ999knV1dU1v+ZVV12VysrK0owZMxqde/r06am8vDwdf/zxadq0aWny5MmpqqoqDRo0KK1atarmuNdffz2VlZWl008/vdbt58+fn6ZMmZKmTJmShgwZkrbeeuuar+fPn1/r2N/97ndpypQp6bbbbksRkU488cSaY1euXFnnsZw0aVKj819zzTWpUCikyy67LM2YMSN9//vfTxUVFemss86qddwdd9yRysrK0h133FHr+jPPPDNVVFSk73//+2nGjBnpsssuS4VCIY0bN67WcUuXLk19+/ZNvXv3ThMnTkwPP/xwOuuss1JEpB/84AeNzgltWR77t2LFitSvX7/UvXv39IMf/CA99thjafLkyWnPPfdMZWVlafr06TXH/uAHP0gRkY466qj01FNP1bnU91iWUv8++9nPpohIl19+eZ3ZP955yKM8NnDy5MnpC1/4QrrtttvSo48+mu6777508sknp4hIX/3qVxu971GjRqXOnTvXub61Gviv//qv6fzzz0933313mj59errzzjvTPvvsU+99OweEDctjA9d5//33U/fu3dMBBxywwfs65phjUkVFRbr66qvTtGnT0vjx41NlZWX67Gc/W+u4UjwPHDx4cLr22mvTb37zmzRt2rQ0bty4tOWWW6bevXunN998s9E5oa3LYwOLOQ8866yz0je+8Y107733phkzZqRf/epX6Ytf/GKKiPStb32r3seylBo4bNiwNH78+PTggw+m6dOnp0mTJqV99903lZWVpYceeqjROfmIRUUGmhunlFK67bbb0s4775wqKirSJz7xiTR+/Pg0ceLEWnG6/PLLU7t27dKjjz5a67azZs1K5eXlacyYMTXXjR07NkVErT8o25BHHnkk7b///qmysjL16NEjfeUrX0lvvfVWrWNee+21FBFp1KhRta5fd1/1XcaOHVvr2H79+jV47LqfM6WUbrjhhhQRaerUqU2a/8c//nEaOHBg6tChQ+rbt28aO3Zs+uCDD2od01DwPvjggzR27NjUt2/f1KFDhzRw4MD0k5/8pN77eeONN9LJJ5+cunfvnjp06JAGDx6cbrvttibNCG1ZXvu3cOHCdP7556cBAwakysrK1Lt37zRy5Mg6y4fhw4c32L6P/92CUuzfhmb/+O8n5FEeG/jUU0+lww47LG277bapffv2qVOnTmmfffZJN954Y1qzZk2j99vQoqK1Gjhx4sS07777ph49eqTy8vLUvXv3dOSRR6aHH3643vtxDggNy2MD15k8eXKKiEZ78N5776WLL744VVVVpfLy8tS3b9906aWX1vrDwJRK8zzw5JNPTgMGDEidO3dO7du3T/369UvnnHOOJQX8rzw2sJjzwNtuuy0ddNBBqWfPnqm8vDxtueWWafjw4ekXv/hFnXlKsYHf+MY30h577JG6deuWysvL07bbbpuOP/749OSTTzZpRj5SSOl/3xgMNkMnnXRSvPbaazFnzpysRwFoVfoH5JkGAnmmgUCeaWDbVZ71ANBcKaWYMWNG3HXXXVmPAtCq9A/IMw0E8kwDgTzTwLbNKyoAAAAAAIDMtMt6AAAAAAAAIL8sKgAAAAAAgMxYVAAAAAAAAJmxqAAAAAAAADJT3tp3uHbt2njzzTejS5cuUSgUWvvugQyllGLFihXRu3fvaNcuf3tS/YN800ANhDzTQA2EvNI//YM8K6aBrb6oePPNN6Oqqqq17xYoIQsWLIg+ffpkPUar0z8gQgOBfNNAIK/0D8izpjSw1RcVXbp0iYiIA+MzUR7tW/vuNxsP/PmFrEeoY+htZ2Y9Qh3bz3wv6xHq+GDLDlmPUEsqob+wsfrDVTH3ke/WdCBv1v3cr83tG122KJ3fmL1+e0bWI9Sy4zeezXoEaBGr48N4In6X+waW2jngovP3y3qEWp76+q1Zj1DHCQd+OusR6liz+O2sR6BIGvjRz/3/ntshupbQeeDxA3fPeoSSV9Z9y6xH2DyktVlPULJWpw9i5rJ79U//NjtlW3bNeoS6CqXzz1AN/dugYhrY6ouKdS/zKo/2UV4onSeppaZrl9L7F6+ssjLrEeooLy+9GKxtb1HRmLy+3HPdz91li3Yl9e94u46l9e+2/zbQZqWP/ifvDSy1c8CyitJqYCn992Gd8naldW4TEVEooX+GaCINjIiIriV2HlhKPS5VZYXSa2BpKr3n5qVG//Rvc1OS/SvFRYX+NUlTGliKv7sAAAAAAEBOWFQAAAAAAACZsagAAAAAAAAyY1EBAAAAAABkxqICAAAAAADIjEUFAAAAAACQGYsKAAAAAAAgMxYVAAAAAABAZiwqAAAAAACAzFhUAAAAAAAAmbGoAAAAAAAAMtOsRcWNN94Y/fv3j8rKyhgyZEj88Y9/3NRzAZQsDQTySv+APNNAIM80EGhpRS8q7r333rjwwgvj8ssvj+effz4OOuigOProo+ONN95oifkASooGAnmlf0CeaSCQZxoItIaiFxXXX399nHHGGXHmmWfGJz/5yfjRj34UVVVVMWHChJaYD6CkaCCQV/oH5JkGAnmmgUBrKGpR8cEHH8TcuXNjxIgRta4fMWJEzJo1a5MOBlBqNBDIK/0D8kwDgTzTQKC1lBdz8JIlS2LNmjXRq1evWtf36tUrFi1aVO9tqquro7q6uubr5cuXN2NMgOwV20D9A9oK54BAnmkgkGeeBwOtpVkfpl0oFGp9nVKqc90648ePj27dutVcqqqqmnOXACWjqQ3UP6CtcQ4I5JkGAnnmeTDQ0opaVPTs2TPKysrqbEwXL15cZ7O6zqWXXhrLli2ruSxYsKD50wJkqNgG6h/QVjgHBPJMA4E88zwYaC1FLSo6dOgQQ4YMiWnTptW6ftq0aXHAAQfUe5uKioro2rVrrQvA5qjYBuof0FY4BwTyTAOBPPM8GGgtRX1GRUTERRddFKeeemoMHTo0hg0bFjfffHO88cYbcc4557TEfAAlRQOBvNI/IM80EMgzDQRaQ9GLii9+8YuxdOnS+M53vhMLFy6MQYMGxe9+97vo169fS8wHUFI0EMgr/QPyTAOBPNNAoDUUvaiIiDjvvPPivPPO29SzAGwWNBDIK/0D8kwDgTzTQKClFfUZFQAAAAAAAJuSRQUAAAAAAJAZiwoAAAAAACAzFhUAAAAAAEBmLCoAAAAAAIDMWFQAAAAAAACZsagAAAAAAAAyY1EBAAAAAABkxqICAAAAAADIjEUFAAAAAACQGYsKAAAAAAAgMxYVAAAAAABAZsqzHoDNSCHrAaBtOGHnPaK80D7rMWrsFE9nPQIAAAAAOeYVFQAAAAAAQGYsKgAAAAAAgMxYVAAAAAAAAJmxqAAAAAAAADJjUQEAAAAAAGTGogIAAAAAAMiMRQUAAAAAAJAZiwoAAAAAACAzFhUAAAAAAEBmLCoAAAAAAIDMWFQAAAAAAACZsagAAAAAAAAyY1EBAAAAAABkpuhFxeOPPx7HHHNM9O7dOwqFQjz44IMtMBZA6dE/IM80EMgzDQTySv+A1lL0omLlypWxxx57xE9/+tOWmAegZOkfkGcaCOSZBgJ5pX9Aaykv9gZHH310HH300S0xC0BJ0z8gzzQQyDMNBPJK/4DWUvSioljV1dVRXV1d8/Xy5ctb+i4BSoL+AXmmgUCeaSCQV/oHNFeLf5j2+PHjo1u3bjWXqqqqlr5LgJKgf0CeaSCQZxoI5JX+Ac3V4ouKSy+9NJYtW1ZzWbBgQUvfJUBJ0D8gzzQQyDMNBPJK/4DmavG3fqqoqIiKioqWvhuAkqN/QJ5pIJBnGgjklf4BzdXir6gAAAAAAABoSNGvqHj33XfjL3/5S83Xr732WsybNy969OgRffv23aTDAZQS/QPyTAOBPNNAIK/0D2gtRS8qnn322Tj00ENrvr7ooosiImLUqFFx++23b7LBAEqN/gF5poFAnmkgkFf6B7SWohcVhxxySKSUWmIWgJKmf0CeaSCQZxoI5JX+Aa3FZ1QAAAAAAACZsagAAAAAAAAyY1EBAAAAAABkxqICAAAAAADIjEUFAAAAAACQGYsKAAAAAAAgMxYVAAAAAABAZiwqAAAAAACAzFhUAAAAAAAAmbGoAAAAAAAAMmNRAQAAAAAAZKY8qztec/AeUSivzOruS96RvbOeoK6+MSvrEep4+M15WY9QxydvPi/rEWrp84f3sh6hRtnqD7IeoSS8e/8OUd65IusxahSyHuBjnhh8f9Yj1NH/wbOzHqGOgec9k/UI0CztKiuiXaFD1mPU2P6meVmPUMuR1++Z9Qh1LLxoQNYj1PGnbz6S9Qh1fGavEVmPUMuatxZnPQL1OOasU6O8hJ4HFw5JWY9Qy8OTb816hDo+s/3eWY+wWSjr3j3rEUqYvyMcEfG5M08pqf7FoVkPUNsfJt+W9Qh1HNl7z6xH2CyUbdkt6xFqK5Rac5o+T6lNDgAAAAAA5IhFBQAAAAAAkBmLCgAAAAAAIDMWFQAAAAAAQGYsKgAAAAAAgMxYVAAAAAAAAJmxqAAAAAAAADJjUQEAAAAAAGTGogIAAAAAAMiMRQUAAAAAAJAZiwoAAAAAACAzFhUAAAAAAEBmLCoAAAAAAIDMWFQAAAAAAACZKWpRMX78+Nhnn32iS5cusc0228Rxxx0XL7/8ckvNBlBSNBDIK/0D8kwDgTzTQKC1FLWomDlzZowePTpmz54d06ZNi9WrV8eIESNi5cqVLTUfQMnQQCCv9A/IMw0E8kwDgdZSXszBU6dOrfX1pEmTYptttom5c+fGwQcfvEkHAyg1Ggjklf4BeaaBQJ5pINBailpUfNyyZcsiIqJHjx4NHlNdXR3V1dU1Xy9fvnxj7hKgZDTWQP0D2irngECeaSCQZ54HAy2l2R+mnVKKiy66KA488MAYNGhQg8eNHz8+unXrVnOpqqpq7l0ClIymNFD/gLbIOSCQZxoI5JnnwUBLavai4vzzz48//elPcffdd2/wuEsvvTSWLVtWc1mwYEFz7xKgZDSlgfoHtEXOAYE800AgzzwPBlpSs9766YILLoiHHnooHn/88ejTp88Gj62oqIiKiopmDQdQipraQP0D2hrngECeaSCQZ54HAy2tqEVFSikuuOCCeOCBB2LGjBnRv3//lpoLoORoIJBX+gfkmQYCeaaBQGspalExevTo+OUvfxm//vWvo0uXLrFo0aKIiOjWrVt07NixRQYEKBUaCOSV/gF5poFAnmkg0FqK+oyKCRMmxLJly+KQQw6J7bbbruZy7733ttR8ACVDA4G80j8gzzQQyDMNBFpL0W/9BJBXGgjklf4BeaaBQJ5pINBainpFBQAAAAAAwKZkUQEAAAAAAGTGogIAAAAAAMiMRQUAAAAAAJAZiwoAAAAAACAzFhUAAAAAAEBmLCoAAAAAAIDMWFQAAAAAAACZsagAAAAAAAAyY1EBAAAAAABkxqICAAAAAADITHnWAwDkzRaffz3KC+2zHqNkHRl7Zj1CHQPjmaxHAAAAAGizvKICAAAAAADIjEUFAAAAAACQGYsKAAAAAAAgMxYVAAAAAABAZiwqAAAAAACAzFhUAAAAAAAAmbGoAAAAAAAAMmNRAQAAAAAAZMaiAgAAAAAAyIxFBQAAAAAAkBmLCgAAAAAAIDMWFQAAAAAAQGYsKgAAAAAAgMwUtaiYMGFCDB48OLp27Rpdu3aNYcOGxe9///uWmg2gpGggkFf6B+SZBgJ5poFAaylqUdGnT5/43ve+F88++2w8++yz8elPfzqOPfbYmD9/fkvNB1AyNBDIK/0D8kwDgTzTQKC1lBdz8DHHHFPr63HjxsWECRNi9uzZsdtuu23SwQBKjQYCeaV/QJ5pIJBnGgi0lqIWFetbs2ZNTJkyJVauXBnDhg3blDMBlDwNBPJK/4A800AgzzQQaElFLypeeOGFGDZsWKxatSq22GKLeOCBB2LXXXdt8Pjq6uqorq6u+Xr58uXNmxSgBBTTQP0D2hLngECeaSCQZ54HA62hqM+oiIjYeeedY968eTF79uw499xzY9SoUfHSSy81ePz48eOjW7duNZeqqqqNGhggS8U0UP+AtsQ5IJBnGgjkmefBQGsoelHRoUOHGDBgQAwdOjTGjx8fe+yxR/z4xz9u8PhLL700li1bVnNZsGDBRg0MkKViGqh/QFviHBDIMw0E8szzYKA1NPszKtZJKdV6SdfHVVRUREVFxcbeDUBJ2lAD9Q9oy5wDAnmmgUCeeR4MtISiFhWXXXZZHH300VFVVRUrVqyIe+65J2bMmBFTp05tqfkASoYGAnmlf0CeaSCQZxoItJaiFhVvvfVWnHrqqbFw4cLo1q1bDB48OKZOnRpHHHFES80HUDI0EMgr/QPyTAOBPNNAoLUUtaiYOHFiS80BUPI0EMgr/QPyTAOBPNNAoLUU/WHaAAAAAAAAm4pFBQAAAAAAkBmLCgAAAAAAIDMWFQAAAAAAQGYsKgAAAAAAgMxYVAAAAAAAAJmxqAAAAAAAADJjUQEAAAAAAGTGogIAAAAAAMiMRQUAAAAAAJAZiwoAAAAAACAzFhUAAAAAAEBmyrMegPqtOXTvrEfYLBzZO+sJ6uobs7IeoZaH35yX9Qg1lq9YG90HZj1F9t69f4co71yR9Rg1ClkP8DHtCinrETYLj+/+QNYj1NH/wbOzHqGWgec9k/UIULR2nTplPUId2980L+sR6jjy+j2zHqGOhRcNyHqEWv70zUeyHqEW54E0xZGnnJn1CHUdmvUAdT18161Zj1DHZ7b3ZxgNWZM+zHoENgOHf/n0rEeoqwT794fJt2U9Qh1H9t4z6xFKWjEN9IoKAAAAAAAgMxYVAAAAAABAZiwqAAAAAACAzFhUAAAAAAAAmbGoAAAAAAAAMmNRAQAAAAAAZMaiAgAAAAAAyIxFBQAAAAAAkBmLCgAAAAAAIDMWFQAAAAAAQGYsKgAAAAAAgMxYVAAAAAAAAJmxqAAAAAAAADKzUYuK8ePHR6FQiAsvvHATjQOwedA/IM80EMgzDQTySv+AltTsRcWcOXPi5ptvjsGDB2/KeQBKnv4BeaaBQJ5pIJBX+ge0tGYtKt5999348pe/HLfcckt07959U88EULL0D8gzDQTyTAOBvNI/oDU0a1ExevToGDlyZBx++OGNHltdXR3Lly+vdQHYXOkfkGcaCOSZBgJ5pX9Aaygv9gb33HNPPPfcczFnzpwmHT9+/Pi46qqrih4MoNToH5BnGgjkmQYCeaV/QGsp6hUVCxYsiDFjxsRdd90VlZWVTbrNpZdeGsuWLau5LFiwoFmDAmRJ/4A800AgzzQQyCv9A1pTUa+omDt3bixevDiGDBlSc92aNWvi8ccfj5/+9KdRXV0dZWVltW5TUVERFRUVm2ZagIzoH5BnGgjkmQYCeaV/QGsqalFx2GGHxQsvvFDrutNOOy122WWXuPjii+vECaCt0D8gzzQQyDMNBPJK/4DWVNSiokuXLjFo0KBa13Xu3Dm22mqrOtcDtCX6B+SZBgJ5poFAXukf0JqK+owKAAAAAACATamoV1TUZ8aMGZtgDIDNj/4BeaaBQJ5pIJBX+ge0FK+oAAAAAAAAMmNRAQAAAAAAZMaiAgAAAAAAyIxFBQAAAAAAkBmLCgAAAAAAIDMWFQAAAAAAQGYsKgAAAAAAgMxYVAAAAAAAAJmxqAAAAAAAADJjUQEAAAAAAGTGogIAAAAAAMhMedYDAOTNFp9/PcoL7bMeg83ckbFn1iPUMTCeyXoEAAAAYDPkFRUAAAAAAEBmLCoAAAAAAIDMWFQAAAAAAACZsagAAAAAAAAyY1EBAAAAAABkxqICAAAAAADIjEUFAAAAAACQGYsKAAAAAAAgMxYVAAAAAABAZiwqAAAAAACAzFhUAAAAAAAAmbGoAAAAAAAAMmNRAQAAAAAAZMaiAgAAAAAAyExRi4orr7wyCoVCrcu2227bUrMBlBQNBPJK/4A800AgzzQQaC3lxd5gt912iz/84Q81X5eVlW3SgQBKmQYCeaV/QJ5pIJBnGgi0hqIXFeXl5TanQG5pIJBX+gfkmQYCeaaBQGso+jMqXnnllejdu3f0798/Tj755Hj11Vc3eHx1dXUsX7681gVgc1VMA/UPaEucAwJ5poFAnnkeDLSGohYV++23X9x5553x8MMPxy233BKLFi2KAw44IJYuXdrgbcaPHx/dunWruVRVVW300ABZKLaB+ge0Fc4BgTzTQCDPPA8GWkshpZSae+OVK1fGjjvuGN/+9rfjoosuqveY6urqqK6urvl6+fLlUVVVFQcd/O9RXl7Z3LuGiIgom/5c1iOUvIffnJf1CDWWr1gb3Qe+GsuWLYuuXbtmPc5Ga6yBDfXvkDg2ygvtW3NUoASsTh/GjPh1m2jgxpwDfrrypCgvdGitURvXrugXGFMC1r73XtYj1LHwogOyHqGWP33zxqxHqKUtnQduTAMPHD62pJ4HF9Y2+48DWkYh6wE2Dw/fdWvWI9Txme33znqEktWWzgEjmv882J8Dsin8YfJtWY9Qx5G998x6hJJWTAOL/oyK9XXu3Dl23333eOWVVxo8pqKiIioqKjbmbgBKUmMN1D+grXIOCOSZBgJ55nkw0FI26q+QVVdXx3//93/Hdtttt6nmAdhsaCCQV/oH5JkGAnmmgUBLKWpR8c1vfjNmzpwZr732Wjz99NNxwgknxPLly2PUqFEtNR9AydBAIK/0D8gzDQTyTAOB1lLUWz/97W9/iy996UuxZMmS2HrrrWP//feP2bNnR79+/VpqPoCSoYFAXukfkGcaCOSZBgKtpahFxT333NNScwCUPA0E8kr/gDzTQCDPNBBoLRv1GRUAAAAAAAAbw6ICAAAAAADIjEUFAAAAAACQGYsKAAAAAAAgMxYVAAAAAABAZiwqAAAAAACAzFhUAAAAAAAAmbGoAAAAAAAAMmNRAQAAAAAAZMaiAgAAAAAAyEx5a99hSikiIlavrm7tu6YNSunDrEcoectXrM16hBrL3/1olnUdyJua/sWHEfl8CCDXVsdH/83KfQNL7b/dyd/b2RytLbV/jiJiTfWqrEeopZTOASOcB5bq8+DC2hL7/ShkPcDmodT+/Y4owf++lxDngKXZPzZP+rf5KaaBhdTKpfzb3/4WVVVVrXmXQIlZsGBB9OnTJ+sxWp3+AREaCOSbBgJ5pX9AnjWlga2+qFi7dm28+eab0aVLlygUmv/XJZYvXx5VVVWxYMGC6Nq16yacsO3wGDWNx6lxm+oxSinFihUronfv3tGuXf7+Buum6l+Ef26bwmPUOI9R02jgpuEcsHV5nBrnMWrcpnyMNFADW4vHqGk8To1zDrhpeB7cujxGjfMYNU0WDWz1t35q167dJt0gd+3a1T9UjfAYNY3HqXGb4jHq1q3bJppm87Op+xfhn9um8Bg1zmPUNBq4cZwDZsPj1DiPUeM21WOkgRrYmjxGTeNxapxzwI3jeXA2PEaN8xg1TWs2MH+rXAAAAAAAoGRYVAAAAAAAAJnZbBcVFRUVMXbs2KioqMh6lJLlMWoaj1PjPEalx+9J4zxGjfMYNY3HqbT4/Wgaj1PjPEaN8xiVHr8njfMYNY3HqXEeo9Lj96RxHqPGeYyaJovHqdU/TBsAAAAAAGCdzfYVFQAAAAAAwObPogIAAAAAAMiMRQUAAAAAAJAZiwoAAAAAACAzm+Wi4sYbb4z+/ftHZWVlDBkyJP74xz9mPVJJGT9+fOyzzz7RpUuX2GabbeK4446Ll19+OeuxStr48eOjUCjEhRdemPUoJeXvf/97nHLKKbHVVltFp06dYs8994y5c+dmPVbuaeCGaWDxNLB+GliaNLBh+lc8/WuYBpYe/dswDSyeBjZMA0uPBm6YBhZPA+uXZf82u0XFvffeGxdeeGFcfvnl8fzzz8dBBx0URx99dLzxxhtZj1YyZs6cGaNHj47Zs2fHtGnTYvXq1TFixIhYuXJl1qOVpDlz5sTNN98cgwcPznqUkvLOO+/Epz71qWjfvn38/ve/j5deeimuu+662HLLLbMeLdc0sHEaWBwNrJ8GliYN3DD9K47+NUwDS4/+NU4Di6OBDdPA0qOBjdPA4mhg/TLvX9rM7Lvvvumcc86pdd0uu+ySLrnkkowmKn2LFy9OEZFmzpyZ9SglZ8WKFWmnnXZK06ZNS8OHD09jxozJeqSScfHFF6cDDzww6zH4GA0sngY2TAMbpoGlSQOLo38N078N08DSo3/F08CGaeCGaWDp0cDiaWDDNLBhWfdvs3pFxQcffBBz586NESNG1Lp+xIgRMWvWrIymKn3Lli2LiIgePXpkPEnpGT16dIwcOTIOP/zwrEcpOQ899FAMHTo0TjzxxNhmm21ir732iltuuSXrsXJNA5tHAxumgQ3TwNKjgcXTv4bp34ZpYGnRv+bRwIZp4IZpYGnRwObRwIZpYMOy7t9mtahYsmRJrFmzJnr16lXr+l69esWiRYsymqq0pZTioosuigMPPDAGDRqU9Tgl5Z577onnnnsuxo8fn/UoJenVV1+NCRMmxE477RQPP/xwnHPOOfH1r3897rzzzqxHyy0NLJ4GNkwDN0wDS48GFkf/GqZ/jdPA0qJ/xdPAhmlg4zSwtGhg8TSwYRq4YVn3r7xV7mUTKxQKtb5OKdW5jo+cf/758ac//SmeeOKJrEcpKQsWLIgxY8bEI488EpWVlVmPU5LWrl0bQ4cOje9+97sREbHXXnvF/PnzY8KECfGVr3wl4+nyTQObTgPrp4GN08DSpYFNo3/107+m0cDSpH9Np4H108Cm0cDSpIFNp4H108DGZd2/zeoVFT179oyysrI6G9PFixfX2awSccEFF8RDDz0U06dPjz59+mQ9TkmZO3duLF68OIYMGRLl5eVRXl4eM2fOjJ/85CdRXl4ea9asyXrEzG233Xax66671rruk5/8pA+rypAGFkcDG6aBjdPA0qOBTad/DdO/ptHA0qJ/xdHAhmlg02hgadHA4mhgwzSwcVn3b7NaVHTo0CGGDBkS06ZNq3X9tGnT4oADDshoqtKTUorzzz8/7r///njssceif//+WY9Ucg477LB44YUXYt68eTWXoUOHxpe//OWYN29elJWVZT1i5j71qU/Fyy+/XOu6P//5z9GvX7+MJkIDm0YDG6eBjdPA0qOBjdO/xulf02hgadG/ptHAxmlg02hgadHAptHAxmlg4zLvXwYf4L1R7rnnntS+ffs0ceLE9NJLL6ULL7wwde7cOb3++utZj1Yyzj333NStW7c0Y8aMtHDhwprLe++9l/VoJW348OFpzJgxWY9RMp555plUXl6exo0bl1555ZU0efLk1KlTp3TXXXdlPVquaWDjNLB5NLA2DSxNGrhh+tc8+leXBpYe/WucBjaPBtalgaVHAxungc2jgbVl3b/NblGRUko/+9nPUr9+/VKHDh3S3nvvnWbOnJn1SCUlIuq9TJo0KevRSpo41fWb3/wmDRo0KFVUVKRddtkl3XzzzVmPRNLAxmhg82hgXRpYmjSwYfrXPPpXPw0sPfq3YRrYPBpYPw0sPRq4YRrYPBpYV5b9K6SUUmu8cgMAAAAAAODjNqvPqAAAAAAAANoWiwoAAAAAACAzFhUZuP3226NQKEShUIgZM2bU+X5KKQYMGBCFQiEOOeSQVp9vQ/7whz/EsGHDolOnTtGzZ8/46le/GosXL27SbZcvXx6XX355DBw4MDp16hTbb799nHjiiTF//vw6x7777rtx4YUXRu/evaOysjL23HPPuOeeezZq9h/96Efx+c9/Pvr379+sx/bDDz+Mq666KnbYYYeoqKiIXXbZJW644YY6x916661x3HHHxQ477BAdO3aMAQMGxLnnnhsLFy7cqPmhLdC/Dffvsccei9NPPz122WWX6Ny5c2y//fZx7LHHxty5czd6/htuuCF22WWXqKioiP79+8dVV10VH374YZNuq3+waeS1gTvssEPNz73+5Zxzzqlz7DPPPBNHHnlkdOnSJbbYYos49NBD48knn9zo+ZvbwCuvvLLe2ddd1j8/bejYysrKjZ4f2oK8NrCY58HPP/98HHfccdG7d+/o1KlT7LLLLvGd73wn3nvvvY2av7kNnDt3bowePTp233336NKlS/Tq1SsOP/zweOyxx+oce/fdd8fBBx8cvXr1ioqKiujdu3ccc8wxMWvWrI2aHdqKvDawqeeBM2bMaPB8a/bs2Rs1/8Y8F46IePHFF+PEE0+MrbfeOioqKmKHHXaI8847r85xkydPjr322isqKyujZ8+e8S//8i+xYMGCjZo9d1rt0zCoMWnSpBQRqUuXLumUU06p8/3p06fXfH/48OGtP2ADZsyYkcrLy9Oxxx6bHnnkkXTXXXel7bffPg0aNCitWrWq0dsffPDBqVOnTunaa69Njz32WLrzzjvTgAEDUpcuXdLrr79e69gjjjgibbnllummm25Kjz32WDrzzDNTRKTJkyc3e/6dd9457b333un0009PW2+9ddGP7ZlnnpkqKirStddem6ZPn54uueSSVCgU0rhx42od17t37/TlL385TZ48Oc2YMSP9/Oc/T3369EnbbbddWrRoUbPnh7ZA/zbcvxNOOCEdeuih6cYbb0wzZsxIU6ZMSfvvv38qLy9Pjz76aLPnv+aaa1KhUEiXXnppmj59err22mtThw4d0llnndWk2+sfbBp5bWC/fv3Spz71qfTUU0/Vurz66qu1jnvmmWdSRUVFOuigg9IDDzyQ7r///rT//vunioqKNGvWrGbPvzENXLBgQZ25n3rqqTRo0KDUsWPH9M4779QcO3bs2BQRaerUqbWOffrpp5s9O7QleW1gU88D58+fnyorK9Mee+yR7r333vToo4+msWPHprKysvS5z32u2fNvTAO/8Y1vpKFDh6brr78+Pfroo+mhhx5Kn/nMZ1JEpDvuuKPWsTfccEO65JJL0q9+9as0Y8aMdPfdd6d99tknlZWVpRkzZjR7fmgr8trApp4Hrvv5v/vd79Y5dsWKFc2ef2OfCz/22GOpY8eOacSIETV9u/POO9O//uu/1jruJz/5SYqIdOaZZ6apU6emW2+9NW233XapX79+6R//+Eez588bi4oMrIvTmWeemTp27JiWLVtW6/unnHJKGjZsWNptt91KKk777LNP2nXXXdOHH35Yc92TTz6ZIiLdeOONG7ztK6+8kiIiXXHFFbWunzVrVoqIdP3119dc95//+Z8pItIvf/nLWsceccQRqXfv3mn16tXNmn/NmjU1/7/Yx/bFF19MhUIhffe73611/VlnnZU6duyYli5dWnPdW2+9Vef2c+bMSRGRrr766uIHhzZE//5Pff2rrx8rVqxIvXr1SocddlizZl+yZEmqrKxMZ599dq3rx40blwqFQpo/f/4Gb69/sOnksYEpffQEdeTIkY0ed+SRR6ZevXqllStX1ly3fPny1LNnz3TAAQc0a/aNbWB9XnvttVQoFOr8IcO6RcXbb7/drFmhrctjA4s5D7z88stTRKS//OUvtY49++yzU0Q06w+6NraB9Z3brV69Og0ePDjtuOOOjd7/P//5z9S+fft06qmnFjc4tEF5bGBKTT8PXLeomDJlykbNu76NbeDKlSvTdtttl0aOHJnWrl3b4HGrVq1K3bp1S8ccc0yt69e1/rLLLmv+D5Ez3vopQ1/60pci4qOXSK6zbNmyuO++++L000+v9zZXXXVV7LffftGjR4/o2rVr7L333jFx4sRIKdUc88QTT0T79u3jm9/8Zq3brnuZ2cSJE4ue9e9//3vMmTMnTj311CgvL6+5/oADDoiBAwfGAw88sMHbt2/fPiIiunXrVuv6LbfcMiKi1kviH3jggdhiiy3ixBNPrHXsaaedFm+++WY8/fTTRc8fEdGuXfP/cX/wwQcjpRSnnXZanZnef//9mDp1as1122yzTZ3bDxkyJMrKyrzkC/6X/tXfv/r6scUWW8Suu+7a7H5MnTo1Vq1aVW+/Ukrx4IMPbvD2+gebXp4aWIwnn3wyDjnkkOjUqVPNdV26dImDDz44Zs2a1ay3kdvYBtbntttui5RSnHnmmUXfFshXA4s5D9zQse3atYsOHToUPf/GNrC+c7uysrIYMmRIk87tunTpEpWVlbUeO8i7PDUwaxvbwClTpsTChQvjW9/6VhQKhQaPe/HFF2PZsmXxmc98ptb1w4YNix49esR9993X7J8hbywqMtS1a9c44YQT4rbbbqu57u6774527drFF7/4xXpv8/rrr8fXvva1+I//+I+4//774/Of/3xccMEFcfXVV9ccc+CBB8Y111wT1113XTz00EMRETF//vwYPXp0nHLKKXHGGWfUHLvuvXTre3+89b344osRETF48OA63xs8eHDN9xvSr1+/OPbYY+OHP/xhTJ8+Pd599934n//5n/j6178effv2jZNPPrnWfX3yk5+sczKz7r4bu6+W8OKLL8bWW28d2267bbNmmjlzZqxZsyZ22223FpsRNif6V3//6rNs2bJ47rnnmt2PdfPtvvvuta7fbrvtomfPno3Or3+w6eWpges8/vjj0aVLl2jfvn3suuuucd1118WaNWtqHfPBBx9ERUVFnduuu+6FF15o0n2tb2Mb+HFr166N22+/PQYMGBDDhw+v95jdd989ysrKolevXvGVr3wl3njjjaLnhrYsTw0s5jxw1KhRseWWW8a5554br776aqxYsSJ++9vfxs9//vMYPXp0dO7ceYP3taH5N1UDIyJWr14df/zjHxs8t1uzZk18+OGH8frrr8e5554bKaUYPXp00fcDbVWeGrhOU84D1xk9enSUl5dH165d48gjj4wnnniiSfexofmb28DHH388Ij7q2oEHHhgdOnSI7t27x5e+9KV48803a4774IMPIiIaPI995ZVXYtWqVc3+OfLEWjtjp59+ehx66KExf/782G233eK2226LE088Mbp06VLv8ZMmTar5/2vXro1DDjkkUkrx4x//OP7t3/6tZsP37W9/Ox5//PEYNWpUPPHEE3HSSSdF375946abbqr167Vr1y7Kyso2uBmMiFi6dGlERPTo0aPO93r06FHz/Q2ZMmVKjB49Oj796U/XXDd48OCYOXNmdO/evdZ9feITn6j3ftafpTUtXbq03p+9c+fO0aFDhw3OtGLFijjvvPOiqqqqwe045JH+1e1ffUaPHh0rV66Myy+/vNH7qc/SpUujoqKi3ie3TZlf/6Bl5KmBI0eOjKFDh8aOO+4Y77zzTkyZMiW++c1vxrx58+IXv/hFzXG77rprzJ49O9auXVvzStjVq1fXvJq2OeeAG9vAj3vkkUdiwYIFMX78+Drf23HHHWPcuHE1H6L4zDPPxLXXXhuPPPJIzJ07N7bffvui54e2Kk8NbOp54A477BBPPfVUHH/88bHjjjvWXP/1r389fvSjHzV6Pw3NvykbGPHRH3D+5S9/afBvIu+2227x8ssvR8RHfxg4derUGDJkSNH3A21ZnhrY1PPAbt26xZgxY+KQQw6JrbbaKv7yl7/E97///TjkkEPiP//zP+PII49s9L7qm39jGvj3v/89IiK+8IUvxNlnnx1XX311/PnPf47LL788hg8fHv/1X/8VnTp1ip133jnatWsXTz75ZK1Xb/z1r3+teUXwO++8E9ttt13RP0PutPZ7TfF/70s3Z86ctHbt2rTjjjumiy66KP3pT39KEZEef/zxlFL9n6Pw6KOPpsMOOyx17do1RUSty8c/qHTJkiWpqqoqVVZWpo4dO6Y//elPzZ558uTJKSLS7Nmz63zv7LPPThUVFY3+GmeccUbq0aNH+uEPf5hmzpyZ7r333jR06NDUv3//Wh8ittNOO6Wjjjqqzu3ffPPNFBFp/Pjxzf451in2Pf+OOOKItMsuu9T7vQ4dOqSvfe1r9X7v/fffT4cffnjq1KlTvY8d5I3+bbh/H3fFFVekiEg33HBDs+c/66yzUmVlZb3fGzhwYDryyCM3eHv9g00nrw2sz/nnn58iIj333HM1102cODFFRDr33HPT3/72t/TGG2+kM844I5WVlaWISPfcc0/R97OxDfy4E044IZWXl6eFCxc26finn346tWvXLn39618v6n6gLcprA5t6Hvjaa6+lAQMGpE996lPpV7/6VZo5c2a69tprU9euXdPpp5/erPk3dQNvueWWFBHpG9/4RoPHvPjii+npp59OU6ZMSYcddljq0qVLmj59elH3A21RXhtYn/rOA+vzzjvvpD59+qTBgwc36342xXPhiKjznPfBBx9MEZFuueWWmutOPfXU1L59+3TTTTelpUuXpv/6r/9K++23X8157Md/n6ift37KWKFQiNNOOy3uuuuuuOmmm2LgwIFx0EEH1XvsM888EyNGjIiIiFtuuSWefPLJmDNnTs3fsn3//fdrHb/VVlvF5z73uVi1alUcddRRdV7qVIytttoqIur/m2z/+Mc/6t2urm/q1KkxceLE+PnPfx4XXnhhHHzwwXHSSSfFtGnT4h//+EdceeWVte6rofuJqH+T29IammnlypXxwQcf1DtTdXV1HH/88fHEE0/EQw89FPvtt19rjAqbDf2r27/1XXXVVXHNNdfEuHHj4vzzz9+o+VetWhXvvfdes+bXP2gZeWlgQ0455ZSIiJg9e3bNdaeffnp873vfi1/84hfRp0+f6Nu3b7z00ks177XcnFckbGwD17dkyZJ46KGHYuTIkXXeDq8h++67bwwcOLDWzwnkp4HFnAdecsklsXz58nj44YfjC1/4Qhx88MHxrW99K370ox/FbbfdFjNnzmzW/JuqgZMmTYqvfe1rcfbZZ8f3v//9Bo/bbbfdYt99940TTjghpk6dGv369YsxY8YUPTu0ZXlpYEPqOw+sz5Zbbhmf/exn409/+lOdn7MpNsVz4Yio82qOI488MgqFQjz33HM1102YMCG++MUvxnnnnRdbbbVV7LXXXrHLLrvEyJEjo6KioubXYsMsKkrAV7/61ViyZEncdNNNdT7gZX333HNPtG/fPn7729/GSSedFAcccEAMHTq0weOnTZsWEyZMiH333TceeOCBjfrwlkGDBkVE/e8N/MILL9R8vyHz5s2LiIh99tmn1vVbbrllDBgwoNb7wu2+++7x3//937F69eo697P+LK1p9913j7fffjsWLVrUpJmqq6vjuOOOi+nTp8eDDz4Yhx12WKvNCpsT/RtQ7/tiXnXVVXHllVfGlVdeGZdddlkzJ//IuhPTj8+/aNGiWLJkSaPz6x+0nDw0sCHpfz/8cd1bPK1z8cUXx5IlS+KFF16I119/PWbNmhXvvPNOdO7cuVlvHbKxDVzfL37xi/jggw+K/hDtlFKdnxPIRwOLOQ+cN29e7LrrrnXeomTdbZvzeRKbqoGTJk2KM888M0aNGhU33XRTo28Xs055eXnsvffe8ec//7m4wSEH8tDAhjR0HrihY5vanfVtbAPr+2yO9a0/f+fOneMXv/hFLFmyJP7rv/4r3nrrrbj99tvj5ZdfjgMOOKDO5/BSP2fMJWD77bePb33rW3HMMcfEqFGjGjyuUChEeXl5lJWV1Vz3/vvv13pPt3UWLlwYp5xySgwfPjxmzZoVn/vc5+KMM86I1157rdkz7rvvvnHXXXfV+sCb2bNnx8svvxyf//znN3j73r171xy/vqVLl8af//zn6NOnT811xx9/fLz77rt1YnrHHXdE7969M/mbuccee2wUCoW44447al1/++23R8eOHeOoo46quW7d3yR+7LHH4r777mvW++hBXuhf7f5FRFx99dVx5ZVXxhVXXBFjx45t1szrO+qoo6KysjJuv/32WtfffvvtUSgU4rjjjtvg7fUPWk4eGtiQO++8MyIi9t9//zrfq6ioiEGDBkW/fv3ijTfeiHvvvTfOOuus6NixY9H3s7ENXN/EiROjd+/ecfTRRzf5NrNnz45XXnml3p8T8i4PDSzmPLB3794xf/78ePfdd2sd+9RTT0VE1DlnbIpN0cDbb789zjzzzDjllFPi1ltvLeoPC1etWhWzZ8+OAQMGFDk5tH15aGBDNnQeuL533nknfvvb38aee+4ZlZWVRd/Pxjbw+OOPj0KhEL///e9rXf/73/8+Ukr1zt+9e/cYPHhw9OzZMx566KF4+eWXvaqsGJm+8VROrf++dBvy8fele/TRR1NEpBNOOCE98sgj6e67705DhgxJO+20U4qI9Nprr6WUUlq9enUaPnx46tWrV8375/7jH/9Iffv2Tfvss0+qrq6u+TWvuuqqVFZWlmbMmNHo3NOnT0/l5eXp+OOPT9OmTUuTJ09OVVVVadCgQWnVqlU1x73++uuprKys1vtorlixIvXr1y917949/eAHP0iPPfZYmjx5ctpzzz1TWVlZnfesPOKII1L37t3TzTffnB577LF01llnpYhId911V72P5aRJkxqdf86cOWnKlClpypQpqaqqKu266641X6//3qB33HFHKisrS3fccUet25955pmpoqIiff/7308zZsxIl112WSoUCmncuHG1jvvsZz+bIiJdfvnl6amnnqp1mT9/fqNzQlumfxvu3w9+8IMUEemoo46q04+nnnqq3seyKf275pprUqFQSJdddlmaMWNG+v73v58qKirSWWedVes4/YOWlccGTp48OX3hC19It912W3r00UfTfffdl04++eQUEemrX/1qrft54YUX0pVXXpl++9vfpmnTpqUf/OAHqWfPnmno0KFpxYoV9T6WrdHAlFKaPXt2ioh02WWXNXg/gwcPTtdee236zW9+k6ZNm5bGjRuXttxyy9S7d+/05ptvNjontHV5bGAx54G//vWvU6FQSPvvv3+6995706OPPprGjRuXtthii7TrrrvWmr+1Gvgf//EfqV27dmnvvfdOTz75ZJ3zu/V//mHDhqXx48enBx98ME2fPj1NmjQp7bvvvqmsrCw99NBDjc4JbV0eG1jMeeCXvvSldPHFF6cpU6ak6dOnp5tvvjntvPPOqby8PE2bNq3ex7I1zgPPP//81K5du3TRRReladOmpZ/97Gepe/fuaa+99qr1mP7qV79KP/nJT9K0adPSb37zm/SNb3wjlZeXp3POOafRGfk/FhUZaG6cUkrptttuSzvvvHOqqKhIn/jEJ9L48eNrPnhwXZwuv/zy1K5du/Too4/Wuu2sWbNSeXl5GjNmTM11Y8eOTRHR5A+3euSRR9L++++fKisrU48ePdJXvvKV9NZbb9U65rXXXksRkUaNGlXr+oULF6bzzz8/DRgwIFVWVqbevXunkSNH1vnDt5Q+OqH7+te/nrbddtvUoUOHNHjw4HT33XfXOe6GG25IEZGmTp3a6OyjRo2q86FD6y7rx62h4H3wwQdp7NixqW/fvqlDhw5p4MCB6Sc/+Umd+2noPiKiqA/whrZI/zbcv+HDh2+wIesrpn8ppfTjH/84DRw4MHXo0CH17ds3jR07Nn3wwQe1jtE/aFl5bOBTTz2VDjvssLTtttum9u3bp06dOqV99tkn3XjjjWnNmjW1bv/yyy+ngw8+OPXo0SN16NAhDRgwIF1xxRXp3XffrTNPazYwpY8+jLFQKKS//vWvDd7HySefnAYMGJA6d+6c2rdvn/r165fOOeccSwr4X3lsYErFPQ9+7LHH0ogRI9K2226bOnbsmAYOHJi+8Y1vpCVLltQ6rrUauKHn0Os/9iml9I1vfCPtscceqVu3bqm8vDxtu+226fjjj09PPvlkk2aEti6PDSzmPHD8+PFp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",
      "text/plain": [
       "<Figure size 2000x2000 with 10 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "r_norm = np.linalg.norm(params_best['R'], axis = 0)\n",
    "plt.figure(figsize = (20,20))\n",
    "for neuron in range(N):\n",
    "    plt.subplot(6,5, neuron+1)\n",
    "    plt.imshow(g[neuron,:,:].T)\n",
    "    plt.title(f'Max: {np.max(g[neuron,:,:]):.2f}, {r_norm[neuron]:.2f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 235,
   "id": "af963234-1493-4207-8ad7-3621c74b7a53",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Pot in Prep: 0.12413638830184937\n",
      "Prep in Pot: 0.6494183540344238\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Pot Act')"
      ]
     },
     "execution_count": 235,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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pCgWI0RERKQoFiNERESkKBYjREREpCgWI0RERKQoFiNERESkKBYjREREpCgWI0RERKQoFiNERESkKBYjREREpCgWI0RERKQoFiNERESkKBYjREREpCgWI0RERKQoFiNERESkKBYjREREpCgWI0RERKQoVRcjL7/8MnQ6ndMjOjpa6bCISOWYO4i0xah0APXp0qULfvjhB8dzg8GgYDREpBXMHUTaofpixGg08hMNEbmMuYNIO1TdTQMABw4cQExMDJKSknDffffh8OHDdV5vtVpRWFjo9CCi5seV3MG8QaQsVRcj11xzDT799FN89913+Oijj5CTk4N+/frh3Llztb4mPT0dISEhjkd8fLwXIyYiNXA1dzBvEClLJ4QQSgfRUMXFxWjXrh2ef/55TJkypcZrrFYrrFar43lhYSHi4+NxYX9bBFtUXXuRStwc00PpEDymXJRhLf6HgoICBAcHKx2O19SXO2rLG9djFIw6P2+GShr13akspUPwmMIiO1p2OOzRvKH6MSNVBQYGomvXrjhw4ECt15jNZpjNZi9GRURqV1/uYN4gUpammgqsViv27t2L1q1bKx0KEWkIcweRuqm6GHn22Wexbt06HDlyBL/++ivuuusuFBYWYty4cUqHRkQqxtxBpC2q7qY5ceIE7r//fuTl5SEiIgLXXnstNm/ejISEBKVDIyIVY+4g0hZVFyOLFy9WOgQi0iDmDiJtUXU3DREREfk+FiNERESkKBYjREREpCgWI0RERKQoFiNERESkKBYjREREpChVT+11B3nrncKLdoUjIa0oF2VKh+Ax5ZB+Ng1tSaUI+fdTjjKAvypqgMIi3/03Rv7305N5w+eLkaKiIgBAQq+jygZCGlL7VvO+oqioCCEhIUqHoVpy3vgZqxSOhLSiZQelI/A8T+YNTe3a2xh2ux2nTp2CxWKBTqdr8OvkXTuzs7N9cndT/nza1tifTwiBoqIixMTEQK9nL21tmDdqxp9P29ScN3y+ZUSv1yMuLq7Rrw8ODvbJ/yll/Pm0rTE/H1tE6se8UTf+fNqmxrzBj0ZERESkKBYjREREpCgWI7Uwm82YPn06zGaz0qF4BH8+bfP1n0+rfP2/C38+bVPzz+fzA1iJiIhI3dgyQkRERIpiMUJERESKYjFCREREimIxQkRERIpiMVKDWbNmISkpCf7+/khJScGGDRuU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",
      "text/plain": [
       "<Figure size 640x480 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Now Extract Movement PCs and Prep PCs, and see how much overlap there is\n",
    "prep_period_times = np.logical_and(np.any(np.abs(inputs) > 0.01, axis = 0), np.all(np.abs(outputs)<0.01 , axis = 0))\n",
    "pot_period_times = np.logical_or(np.logical_and(np.all(np.abs(inputs) < 0.01,axis=0), np.any(np.abs(outputs)>0.01, axis = 0)), np.logical_and(np.all(np.abs(inputs) < 0.01,axis=0), np.all(np.abs(outputs)<0.01, axis = 0)))\n",
    "pot_period_times = np.logical_and(np.all(np.abs(inputs) < 0.01,axis=0), np.any(np.abs(outputs)>0.01, axis = 0))\n",
    "\n",
    "plt.subplot(2,2,1)\n",
    "plt.imshow(prep_period_times)\n",
    "plt.title('Prep Periods')\n",
    "\n",
    "plt.subplot(2,2,2)\n",
    "plt.imshow(pot_period_times)\n",
    "plt.title('Pot Periods')\n",
    "\n",
    "prep_act = g[:,prep_period_times.T]\n",
    "prep_act = np.reshape(prep_act, [N, int(prep_act.size/N)])\n",
    "pot_act = g[:,pot_period_times.T]\n",
    "pot_act = np.reshape(pot_act, [N, int(pot_act.size/N)])\n",
    "\n",
    "prep_PCs, prep_PC_vals = get_PCs(prep_act, num_eigs = N)\n",
    "pot_PCs, pot_PC_vals = get_PCs(pot_act, num_eigs = N)\n",
    "\n",
    "plt.subplot(2,2,3)\n",
    "prep_in_prep_var = plot_var(prep_act, prep_PCs)\n",
    "pot_in_prep_var = plot_var(pot_act, prep_PCs)\n",
    "\n",
    "thresh_var = 0.001\n",
    "\n",
    "plt.title('Prep Act')\n",
    "print(f'Pot in Prep: {np.sum(pot_in_prep_var[prep_in_prep_var > thresh_var])}')\n",
    "\n",
    "plt.subplot(2,2,4)\n",
    "pot_in_pot_var = plot_var(pot_act, pot_PCs)\n",
    "prep_in_pot_var = plot_var(prep_act, pot_PCs)\n",
    "print(f'Prep in Pot: {np.sum(prep_in_pot_var[pot_in_pot_var > thresh_var])}')\n",
    "\n",
    "plt.title('Pot Act')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "id": "555836ce-3779-4aa6-8eb8-c0c42763646d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.12413639"
      ]
     },
     "execution_count": 230,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 223,
   "id": "d83f7693-0de6-499e-afb9-ae48c3784aa8",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_var(vecs, PCs):\n",
    "    demeaned_act = vecs - np.mean(vecs, axis = 1)[:,None]\n",
    "    total_var = np.sum(np.power(demeaned_act, 2))\n",
    "    PC_var = np.sum(np.power(PCs.T@demeaned_act, 2), axis = 1)/total_var\n",
    "    plt.plot(PC_var)\n",
    "    return PC_var"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rep_theo",
   "language": "python",
   "name": "rep_theo"
  },
  "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.11.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
