{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Notebook for running SCOT on SNARE-seq Cell Mixture Data\n",
    "**Note:** This version of the notebook runs a new setting for SCOT, where we use correlation as a metric for building kNN graphs and use connectivity information from this graph in intra-domain similarity matrices fed into the optimal transport algorithm.  \n",
    "\n",
    "**Access to the raw dataset:** Gene Expression Omnibus accession no. GSE126074. \n",
    "SNARE-seq data in `/data` folder containes the version with dimensionality reduction techniques applied from the original SNARE-seq paper (https://www.nature.com/articles/s41587-019-0290-0)    \n",
    "\n",
    "SCOT software has been updated on 20 September 2020. It now outputs error statements for convergence issues at low epsilon values. When it runs into numerical instabilities in convergence, it outputs the original data, the GW distance from the uniform coupling, and a converged flag = False. If you run into such an error, please try using a larger epsilon value for the entropic regularization.    \n",
    "\n",
    "If you have any questions, e-mail: ritambhara@brown.edu, pinar_demetci@brown.edu, rebecca_santorella@brown.edu  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.insert(1, '../src/')\n",
    "import utils as ut\n",
    "import evals as evals\n",
    "import scot2 as sc\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dimensions of input datasets are:  X=  (1047, 19)  y=  (1047, 10)\n"
     ]
    }
   ],
   "source": [
    "X=np.load(\"../data/scatac_feat.npy\") \n",
    "y=np.load(\"../data/scrna_feat.npy\")\n",
    "print(\"Dimensions of input datasets are: \", \"X= \", X.shape, \" y= \", y.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[60197.,  6248.,  4661., ..., 47172.,  4581., 38815.],\n",
       "       [66853.,  5991., 77816., ...,  2792., 19038.,  1547.],\n",
       "       [13579.,  1527.,  1360., ...,  2404.,  1607.,  2412.],\n",
       "       ...,\n",
       "       [26790.,  3789.,  5076., ...,  1845.,  2987.,  1953.],\n",
       "       [10934.,  1848., 16540., ...,  1156.,  2437.,   938.],\n",
       "       [83110., 12502., 45698., ...,  7958., 22743.,  3810.]])"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "It.  |Err         \n",
      "-------------------\n",
      "    0|2.152968e-03|\n",
      "   10|6.118185e-04|\n",
      "   20|8.246992e-05|\n",
      "   30|3.894956e-05|\n",
      "   40|3.216470e-05|\n",
      "   50|3.068255e-05|\n",
      "   60|2.850152e-05|\n",
      "   70|2.484922e-05|\n",
      "   80|2.042939e-05|\n",
      "   90|1.618798e-05|\n",
      "  100|1.259759e-05|\n",
      "  110|9.709774e-06|\n",
      "  120|7.426016e-06|\n",
      "  130|5.636091e-06|\n",
      "  140|4.246817e-06|\n",
      "  150|3.179940e-06|\n",
      "  160|2.368862e-06|\n",
      "  170|1.757536e-06|\n",
      "  180|1.299939e-06|\n",
      "  190|9.592410e-07|\n",
      "It.  |Err         \n",
      "-------------------\n",
      "  200|7.066033e-07|\n",
      "  210|5.198315e-07|\n",
      "  220|3.820633e-07|\n",
      "  230|2.806101e-07|\n",
      "  240|2.059904e-07|\n",
      "  250|1.511563e-07|\n",
      "  260|1.108881e-07|\n",
      "  270|8.133075e-08|\n",
      "  280|5.964305e-08|\n",
      "  290|4.373381e-08|\n",
      "  300|3.206565e-08|\n",
      "  310|2.350916e-08|\n",
      "  320|1.723517e-08|\n",
      "  330|1.263514e-08|\n",
      "  340|9.262639e-09|\n",
      "  350|6.790190e-09|\n",
      "  360|4.977643e-09|\n",
      "  370|3.648897e-09|\n",
      "  380|2.674833e-09|\n",
      "  390|1.960783e-09|\n",
      "It.  |Err         \n",
      "-------------------\n",
      "  400|1.437344e-09|\n",
      "  410|1.053637e-09|\n",
      "  420|7.723607e-10|\n"
     ]
    }
   ],
   "source": [
    "# initialize SCOT object\n",
    "scot=sc.SCOT(X, y)\n",
    "# call the alignment with l2 normalization \n",
    "X_new, y_new = scot.align(k=50, e=0.0005,  normalize=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.035103352935268804]"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scot.gwdist"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "##### Evaluate results:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average FOSCTTM score for this alignment with X onto Y is:  0.1565206791324023\n"
     ]
    }
   ],
   "source": [
    "fracs=evals.calc_domainAveraged_FOSCTTM(X_new, y_new[0])\n",
    "print(\"Average FOSCTTM score for this alignment with X onto Y is: \", np.mean(fracs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYIAAAEGCAYAAABo25JHAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO3deXgUVdb48e8hbLIoIIJAQEJYEwIBQogiAgoScUEUBHxHwFFxYVFnHBUdUfnpOzIyo+iLzgAijuMAiqggKCiCosKQBFD2HSSIGCL7mpDz++N2mhBCEyCVTtLn8zz9dNfSVafS0Kfr1q1zRVUxxhgTukoFOwBjjDHBZYnAGGNCnCUCY4wJcZYIjDEmxFkiMMaYEFc62AGcq+rVq2v9+vWDHYYxxhQrKSkpu1X1sryWFbtEUL9+fZKTk4MdhjHGFCsisu1My6xpyBhjQpwlAmOMCXGWCIwxJsQVu2sEecnIyCA1NZWjR48GOxRjQlr58uUJDw+nTJkywQ7FnIMSkQhSU1OpXLky9evXR0SCHY4xIUlVSU9PJzU1lYiIiGCHY86Bp01DIpIoIutEZKOIPJnH8noiMl9ElonIjyLS/Xz2c/ToUS699FJLAsYEkYhw6aWX2pl5MeRZIhCRMGAscAMQBfQTkahcq/0ZeF9VWwF9gTcuYH/n+1ZjTAGx/4fFk5dnBPHARlXdrKrHgSlAj1zrKHCx7/UlwM8exmOMMSYPXiaCOsD2HNOpvnk5PQf8TkRSgdnA0Lw2JCKDRCRZRJLT0tK8iPWCvfjii0RHR9OiRQtiY2P573//C7gL2U8++SSNGjWiefPmxMfH89lnnwGwb98++vfvT2RkJJGRkfTv3599+/axYsUKYmNjiY2NpVq1akRERBAbG0uXLl3yHU/9+vXZvXs3AFdddVXBH/AFWr58ObNnz85z2YIFC7jkkkv8f4Ocxz1u3DiaNm1K06ZNiY+P59tvv/Uv+/TTT2nVqhUtW7YkKiqKf/7zn/5l//rXv2jevDnR0dFERUUxevRoBg8eTGxsLFFRUVx00UX+/YkIsbGxNGzY8JQ4vv/+ezp16kS9evXIOY7HrbfeSqVKlTz4KxlTSFTVkwfQG5iQY/ou4PVc6/wB+KPv9ZXAaqBUoO22adNGc1u9evVp8wrT999/rwkJCXr06FFVVU1LS9MdO3aoquoTTzyh/fv39y/75ZdfdOrUqaqqevvtt+uzzz7r386IESO0V69ep2x7wIAB+sEHH5xzTFdccYWmpaWdz+EUirffflsHDx6c57L58+frjTfeeNr8mTNnauvWrf3HlZKSonXr1tWdO3fq8ePHtVatWrp9+3ZVVT169KiuXbtWVVVnz56trVq18n8mR44c0XHjxvm3u2XLFo2Ojs5XHB07dtSYmBhduHChqqru2bNH4+PjtWLFiuf6Jyixgv3/sUT65RfVDh1UZ806700AyXqG71UvzwhSgbo5psM5vennHuB9AFVdBJQHqnsYkyd27txJ9erVKVeuHADVq1endu3aHD58mPHjx/P666/7l9WsWZM77riDjRs3kpKSwjPPPOPfzogRI0hOTmbTpk353vett95KmzZtiI6OZty4cXmuk/1rNSsri4ceeojo6GhuuukmunfvzrRp0wB3BvHss8/SunVrYmJiWLt2LQDPPfccAwYM4Prrr6d+/fpMnz6dxx9/nJiYGBITE8nIyAAgJSWFjh070qZNG7p168bOnTsB6NSpE0888QTx8fE0btyYhQsXcvz4cUaMGMHUqVOJjY1l6tSp+TrWUaNG8fLLL1O9uvsn0rp1awYMGMDYsWM5cOAAmZmZXHrppQCUK1eOJk2aAPCXv/yF0aNHU7t2bcB1cbzvvvvy/TfOrW/fvkyZMgWA6dOnc9ttt533tozJl0OHYOFC8J3lFzQvE0ES0EhEIkSkLO5i8Ixc6/wEXAcgIs1wiaBotv0EcP3117N9+3YaN27MQw89xNdffw3Axo0bqVevHhdffPFp71m9ejWxsbGEhYX554WFhREbG8uqVavyve+JEyeSkpJCcnIyr732Gunp6Wdcd/r06WzdupUVK1YwYcIEFi1adMry6tWrs3TpUh588EFGjx7tn79p0yZmzZrFJ598wu9+9zs6d+7MihUruOiii5g1axYZGRkMHTqUadOmkZKSwu9//3uefvpp//szMzNZsmQJr776Ks8//zxly5Zl5MiR9OnTh+XLl9OnT5/TYl24cKG/SebFF18EYNWqVbRp0+aU9eLi4li1ahXVqlXjlltu4YorrqBfv3689957ZGVlAbBy5crT3nchrrvuOr755htOnDjBlClT8ozfmAKVmemeS3vT49+z+whUNVNEhgBzgDBgoqquEpGRuFOUGcAfgfEi8ijuwvFA3ylMsVKpUiVSUlJYuHAh8+fPp0+fPrz00ku0bt36jO9R1Tx7WJxp/pm89tprfPTRRwBs376dDRs2+H8V5/btt9/Su3dvSpUqxeWXX07nzp1PWZ79y7ZNmzZMnz7dP/+GG26gTJkyxMTEcOLECRITEwGIiYlh69atrFu3jpUrV9K1a1cATpw4Qa1atfLc7tatW/N1XB06dODTTz8963o5/14TJkxgxYoVfPnll4wePZovvviCSZMm5Wt/5yIsLIyrr76aqVOncuTIEawarvFccU0EAKo6G3cROOe8ETlerwbaexlDYQkLC6NTp0506tSJmJgY3nnnHe644w5++uknDhw4QOXKlU9ZPzo6mmXLlpGVlUWpUu7ELCsrix9++IFmzZrla58LFizgyy+/ZNGiRVSoUIFOnToF7MN9thyb3XwVFhZGZvY/vBzzS5UqRZkyZfxfvKVKlSIzMxNVJTo6+rQzjLNt91xFRUWRkpLCtdde65+3dOlSoqJO9kqOiYkhJiaGu+66i4iICCZNmkR0dPRp77tQffv2pWfPnjz33HMFtk1jzsjjRGC1hgrAunXr2LBhg396+fLlXHHFFVSoUIF77rmHYcOGcfz4ccBdT/j3v/9Nw4YNadWqFS+88IL/fS+88AKtW7emYcOG+drvvn37qFq1KhUqVGDt2rUsXrw44PpXX301H374IVlZWezatYsFCxac+8HmoUmTJqSlpfkTQUZGxlmbtypXrsyBAwfOaT+PP/44TzzxhL/5a/ny5UyaNImHHnqIgwcPnnI82Z8BwPDhw3n88cf55ZdfADh27BivvfbaOe07tw4dOjB8+HD69et3QdsxJl/KlYO4OKhWzZPNl4gSE8F28OBBhg4dyt69eyldujQNGzb0X7h94YUX+POf/0xUVBTly5enYsWKjBw5EoC33nqLoUOH0rBhQ1SVK6+8krfeeivf+01MTOQf//gHLVq0oEmTJiQkJARc//bbb2fevHk0b96cxo0b065dOy655JLzP3CfsmXLMm3aNIYNG8a+ffvIzMzkkUceITo6+ozv6dy5My+99BKxsbEMHz48X+3st9xyCzt27OCqq65CRKhcuTL//ve/qVWrFgcOHOCvf/0r999/PxdddBEVK1b0Nwt1796dXbt20aVLF39T0u9///sLOmYR4bHHHrugbRiTb02aQFKSZ5uX4tYkHxcXp7kHplmzZk2+m1NC3cGDB6lUqRLp6enEx8fz3Xffcfnllwc7LFOC2P/HoklEUlQ1Lq9l1jQUYm666SZiY2Pp0KEDzzzzjCUBY4qD5GRo1co9e6BkNg116nT6vDvugIcegsOHoXsete0GDnSP3buhV69TlxVQW3pRUFDXBYwxhWjfPli+HI4c8WTzdkZgjDFFnce9hjwrMeHVoyiWmAg1XpWvmDRpkjZs2FAbNmyokyZNynOd999/X6OiolRENCkpyT9/y5YtWr58eW3ZsqW2bNlS77//fv+yY8eO6X333aeNGjXSJk2a6LRp01TVlbmoXr26/z3jx49XVdVly5ZpQkKCRkVFaUxMjE6ZMsW/rc2bN2t8fLw2bNhQ77jjDj127Jh/2dSpU7VZs2YaFRWl/fr1U1XVr776yr/9li1barly5fSjjz5SVdV58+Zpq1atNDo6Wvv3768ZGRmqqrpmzRpNSEjQsmXL6ssvv+zf/pEjR7Rt27baokULjYqK0hEjRviX3Xnnndq4cWONjo7Wu+++W48fP37K323JkiVaqlSpU8qV5PX3PnTokHbv3l2bNGmiUVFR+sQTT/jXf/PNN7V58+basmVLbd++va5atSrPz8j+P3rg009VQXXJkvPeBAFKTAT9i/1cH6GaCDIzM4Mdgp8XiSA9PV0jIiI0PT1df/vtN42IiNDffvvttPVWr16ta9eu1Y4dO56WCPKqF6Tqajg9/fTTqqp64sQJf+xnqne0bt06Xb9+vaqq7tixQy+//HLds2ePqqr27t1bJ0+erKqq999/v77xxhuqqrp+/XqNjY31x7xr1648j7Fq1ap66NAhPXHihIaHh+u6detUVfWZZ57RCRMm+N+7ZMkSfeqpp05JBFlZWXrgwAFVVT1+/LjGx8frokWLVFV11qxZmpWVpVlZWdq3b19/XKru307nzp31hhtu8CeCM/29Dx06pF999ZWqugR69dVX6+zZs1VVdd++ff5tfvLJJ9qtW7c8/96h8P+x0H38sfu6Xrr0vDcRKBFY05AHHnzwQeLi4oiOjubZZ58F4LPPPuOOO+7wr7NgwQJuvvlmAObOncuVV15J69at6d27NwcPHgRc/Z+RI0dy9dVX88EHHzB+/Hjatm1Ly5Ytuf322zl8+DDgSkAkJCTQtm1bRowYcUolzJdffpm2bdvSokULfyw5vfnmmzz++OP+6UmTJjF0qCsCe7Y6Rlu3bqV58+b+6dGjR/tvsNq0aROJiYm0adOGDh06+GsXncmcOXPo2rUr1apVo2rVqnTt2pXPP//8tPWaNWvmryGUXxMnTmT48OGAuwkuu1bRmTRu3JhGjRoBULt2bWrUqEFaWhqqyldffUUv3zWkAQMG8PHHHwMwfvx4Bg8eTNWqVQGoUaPGadudNm0aN9xwAxUqVCA9PZ1y5crRuHFjALp27cqHH37of2/btm1PG+5RRPyfbUZGBhkZGf6b+7p3746IICLEx8eTmprqf9/rr7/O7bfffkpMZ/p7V6hQwX/HedmyZWndurV/WzlLpRw6dMjGHihM1aq5a595lKspCJYIPPDiiy+SnJzMjz/+yNdff82PP/5I165dWbx4MYcOHQJg6tSp9OnTh927d/PCCy/w5ZdfsnTpUuLi4vj73//u31b58uX59ttv6du3L7fddhtJSUn+u4+z7zl4+OGHefjhh0lKSvIXVgOXYDZs2MCSJUtYvnw5KSkpfPPNN6fE2qtXr1PKSWTHBedWxyi3QYMG8frrr5OSksLo0aN56KGHAJgxYwYjRow4bf0dO3ZQt+7JGoXh4eHs2LEj3/sD2LJlC61ataJjx44sXLgQgL179wLwzDPP+BPtrl27/O/58MMPadGiBb169WL79u2nbXPJkiUcP36cyMhI0tPTqVKlCqV97bQ5Y1y/fj3r16+nffv2JCQk5JnEpkyZ4r8BrXr16mRkZJDdFXratGl57j+3EydOEBsbS40aNejatSvt2rU7ZXlGRgbvvvuuvwzIjh07+Oijj3jggQdOWS8/f++9e/cyc+ZMrrvuOv+8sWPHEhkZyeOPP37BN+WZc9ChA8yfD5GRnmzeEoEH3n//fVq3bk2rVq1YtWoVq1evpnTp0iQmJjJz5kwyMzOZNWsWPXr0YPHixaxevZr27dsTGxvLO++8w7Zt2/zbynmj1cqVK+nQoQMxMTG89957/rt3Fy1aRO/evQG48847/evPnTuXuXPn0qpVK1q3bs3atWtPuQMa4LLLLqNBgwYsXryY9PR01q1bR/v2rurHa6+9RsuWLUlISPDXMcqPgwcP8v3339O7d29iY2O5//77/dVIb7nlFv8NdTlpHveznMsvzlq1avHTTz+xbNky/v73v3PnnXeyf/9+MjMzSU1NpX379ixdupQrr7zSfyPYzTffzNatW/nxxx/p0qULAwYMOGWbO3fu5K677uLtt9+mVKlSAWPMzMxkw4YNLFiwgMmTJ3Pvvff6k1D2tlasWEG3bt3875syZQqPPvoo8fHxVK5c2Z9gAgkLC2P58uWkpqayZMkSVq5cecryhx56iGuuuYYOHToA8MgjjzBq1KhTihvC2f/emZmZ9OvXj2HDhtGgQQP//MGDB7Np0yZGjRp1yl3xpngrmd1Hg2jLli2MHj2apKQkqlatysCBA/31f/r06cPYsWOpVq0abdu2pXLlyqgqXbt2ZfLkyXlur2LFiv7XAwcO5OOPP6Zly5ZMmjTprF1BVZXhw4dz//33B1yvT58+vP/++zRt2pSePXsiIvmqY1S6dGl/hU/AvzwrK4sqVaqwfPnygPvNKTw8/JTjSU1NpVNe3YDPoFy5cv6aRm3atCEyMpL169fTpk0bKlSoQM+ePQHo3bu3/0wqZ3G+++67jyeeeMI/vX//fm688UZeeOEF/x3b1atXZ+/evWRmZlK6dGlSU1P9Z2Dh4eEkJCRQpkwZIiIiaNKkCRs2bKBt27aA+3HQs2fPU5p7rrzySv+Zy9y5c1m/fn2+j7dKlSp06tSJzz//3N889/zzz5OWlnbKgDzJycn07dsXgN27dzN79mxKly591r/3oEGDaNSoEY888kie++/bty8PPvhgvuM1F2jaNBg+3J0VhIcX+ObtjKCA7d+/n4oVK3LJJZewa9cu/2hk4GrzL126lPHjx/t/6SckJPDdd9+xceNGAA4fPnzGL4QDBw5Qq1YtMjIyeO+99/zzExIS/O3L2XXyAbp168bEiRP91xx27NjBr7/+etp2b7vtNj7++GMmT57sjys/dYxq1qzJr7/+Snp6OseOHfNXC7344ouJiIjggw8+AFxC+uGHHwL+3bp168bcuXPZs2cPe/bsYe7cuf5fz/mRlpbGiRMnANi8eTMbNmygQYMGiAg333yz/0tv3rx5/iJ12Wcp4Jqssu+GPX78OD179qR///7+My1wv5g7d+7sH8PhnXfeoUcPN/rqrbfeyvz58wH3hbt+/fpTfklPnjz5tLpE2Z/FsWPHGDVq1GnNN3kdY/ZZxpEjR/jyyy9p2rQp4Cqvzpkzh8mTJ/uLGIL7YbJ161a2bt1Kr169eOONN7j11lsD/r3//Oc/s2/fPl599dVT9p/zjHDWrFn+6yimEOzdC77vCE+c6SpyUX0Uh15DAwYM0KZNm2r37t21Z8+e+vbbb/uXDR48WCtWrKiHDh3yz5s3b57GxcVpTEyMxsTE6CeffKKqp/fOeeONN7R+/frasWNHHTJkiA4YMEBVXY+V+Ph4bdu2rT733HNau3Zt/3teffVVbd68uTZv3lwTEhJ048aNecZ84403akREhH/66NGjmpiYqDExMdqrVy/t2LGjzp8//7S4xowZo5GRkdqlSxcdMGCAf8S1zZs3a7du3bRFixbarFkzff7551XV9TZ55pln8ozhrbfe0sjISI2MjNSJEyf6599zzz3+HkLTp0/XOnXqaNmyZbVGjRp6/fXXq6rqtGnTNCoqSlu0aKGtWrXSGTNm+N+/detW7dChg8bExOi1116r27ZtU1XVJ5980v+eTp066Zo1a1RV9d1339XSpUuf0u1z2bJlqqq6adMmbdu2rUZGRmqvXr38I89lZWXpo48+qs2aNdPmzZv7exapuh5NtWvX1hMnTpxyvI899pg2bdpUGzdurK+88op//s6dO7VOnTpauXJlveSSS7ROnTq6b98+/eGHHzQ2NlZjYmI0Ojra/zdVVQ0LC9MGDRr44825LFvu0e7y+ntv375dAW3atOlp3WqHDRumUVFR2rJlS+3UqZOuXLkyz8+xqP1/LBHefNP1Gtq587w3QYBeQ1ZrqAQ4fPgwF110kb/defLkyXzyySfBDsuEqFD//+iJ11+HYcMgLQ3O0uvtTALVGrJrBCVASkoKQ4YMQVWpUqUKEydODHZIxpiCVJwHphGRRGAMboSyCar6Uq7lrwDZw2RVAGqoahUvYyqJOnTocNY2eGNMMRYRATff7MYl8IBniUBEwoCxQFfcQPZJIjJD3ahkAKjqoznWHwq0Ot/9qZ7bEI/GmIJX3Jqai41bb3UPj3jZayge2Kiqm1X1ODAF6BFg/X5A3n0oz6J8+fKkp6fbP0JjgkhVSU9Pp3z58sEOxZwjL5uG6gA5b5VMBdrltaKIXAFEAF+dYfkgYBBAvXr1TlseHh5OamoqaWlpFxiyMeZClC9fnnAP+rmHvFGj4NVX4eefwYOWDy8TQV7Rnukne19gmqqeyGuhqo4DxoHrNZR7efZNPMYYUyLt3+/GSvGo+dvLpqFUoG6O6XDg5zOs25fzbBYyxpgSLyPDu7EI8DYRJAGNRCRCRMrivuxn5F5JRJoAVYFFHsZijDHFV2Zm8UwEqpoJDAHmAGuA91V1lYiMFJFbcqzaD5iidqXXGGPylpkJucqSFyRP7yNQ1dnA7FzzRuSafs7LGIwxpthr0waOHfNs83ZnsTHGFHUDBriHR6z6qDHGhDhLBMYYU9Tdcw/kGBa2oFkiMMaYou7wYTh+3LPNWyIwxpiizuNeQ5YIjDGmqDt2zBKBMcaEtEOHoFIlzzZv3UeNMaaou/FGTzdvicAYY4q6P/zB081b05AxxhR1x46Bh1V4LBEYY0xRV6cODBni2eYtERhjTFGmCgcOeHqx2BKBMcYUZenp7may2rU924UlAmOMKcq2+0b8rVs38HoXwBKBMcYUZamp7tnDsaA9TQQikigi60Rko4g8eYZ17hCR1SKySkT+42U8xhhT7EREwJNPQmSkZ7vw7D4CEQkDxgJdceMXJ4nIDFVdnWOdRsBwoL2q7hGRGl7FY4wxxVLz5vCXv3i6Cy/PCOKBjaq6WVWPA1OAHrnWuQ8Yq6p7AFT1Vw/jMcaY4mfHDti/39NdeJkI6gDbc0yn+ubl1BhoLCLfichiEUn0MB5jjCl++vTxvMSEl4lA8piX+9a40kAjoBNuEPsJIlLltA2JDBKRZBFJTktLK/BAjTGmSFq/Hr77ztNBacDbRJAK5OzvFA78nMc6n6hqhqpuAdbhEsMpVHWcqsapatxll13mWcDGGFOkfPqpe376aU9342UiSAIaiUiEiJQF+gIzcq3zMdAZQESq45qKNnsYkzHGFB9bt8LFF3vadRQ8TASqmgkMAeYAa4D3VXWViIwUkVt8q80B0kVkNTAf+JOqpnsVkzHGFCvbtsEVV3i+G1EPK9p5IS4uTpOTk4MdhjHGeG/zZtizB9q0ueBNiUiKqsbltczGIzDGmKKqQYNC2Y2VmDDGmKLo0CF4/XXYuNHzXVkiMMaYomjTJhg2DJYu9XxXlgiMMaYoyi4252HV0WxnvEYgItUCvVFVfyv4cIwxxgAny0pUOe0e2wIX6GLxbtwNX5m+6Zx3CitQOFcxjDEmFB086J49HJksW6BE8Dqu9MN3wGTgWy1ufU2NMaa4OnTIPRdCIjjjNQJVfRiIBT4A7gKWichfRSTC86iMMSbU3X23qzV0ySWe7yrgfQS+M4D5IrIMVyLi/wEbgPGeR2aMMaHs4ovdoxCc8YxARCqKyJ0i8gkwG6gEtFZVSwLGGOO1WbPg//6vUHYV6IzgV9yv/8nARtwF4rYi0hZAVad7H54xxoSot9+GVatgyBDPdxUoEbzve27qe+SkgCUCY4zxyvbtnlcdzRYoEcy0X/3GGBMEx47B2rXQr1+h7C7QncV/LpQIjDHGnGrFCndDWZcuhbI7KzFhjDFFza+/uuf69Qtld4GahpqKyI95zBdcz9IWHsVkjDGhrXt31zwUFlYouwuUCLYAN1/IxkUkERgDhAETVPWlXMsHAi8DO3yz/k9VJ1zIPo0xpkQoW7bQdhUoERxT1W3nu2ERCQPGAl1xNYuSRGSGqq7OtepUVfW+f5QxxhQXU6bA4sXw6quFsrtA1whaXuC244GNqrpZVY8DU4AeF7hNY4wp+b7+GiZPLrTdBUoEeV0fOBd1gO05plN983K7XUR+FJFpIpJn4W0RGSQiySKSnJaWdoFhGWNMEbd/P1SuXGi7C5QILrTSqOQxL/c2ZwL1fReevwTeyTMQ1XGqGqeqcZdddtkFhmWMMUXc/v2FVmcIAl8jaCEi+/OYn91r6GxRpgI5f+GHAz/nXEFV03NMjgdGnWWbxhhT8u3bV2QSwQpVbXUB204CGvnKVu/AVS+9M+cKIlJLVXf6Jm8B1lzA/owxpmRQhdq1C213ActQXwhVzRSRIcAcXPfRiaq6SkRGAsmqOgMYJiK34EZB+w0Y6FU8xhhTbCxc6JJBIQmUCD640I2r6mxcCeuc80bkeD0cGH6h+zHGmBJDFUTco5AEulhcVUQeyD1TRB4VEWvLN8YYL3z0Edx4I6Snn33dAhIoEdwIjMtj/hjfMmOMMQUtLQ1mz3YlJgpJwO6jqpqVx8ws8u4aaowx5kLt3eueq1QptF0GSgSHRaRR7pm+eUe8C8kYY0LYvn1QpgxcdFGh7TLQxeIRwGci8gKQ4psXh7u4+4jXgRljTEjau9edDRTixeIzJgJV/UxEbgX+BAz1zV4J3K6qKwojOGOMCTk1a0JsbKHuMuB9BKq6EhiQPS0iVYG9XgdljDEh69lnC32XZ7xGICIjRKSp73U5EfkK2ATsEpHCGT/NGGOM5wJdLO4DrPO9HuBb9zKgI/C/HsdljDGh58gRaNYM3smz/qZnAiWC46r+e5y7AZNV9YSqrsHD0hTGGBOy9u+HtWvh8OFC3W2gRHBMRJqLyGVAZ2BujmUVvA3LGGNC0H5fwedCrDwKgX/ZPwxMwzUHvaKqWwBEpDuwrBBiM8aY0FLUEoGq/hdomsf80wrJGWOMKQBBSgSBmobwNQ294xsmMsn3OqawgjPGmJBSqRJ06waXX16ouw3UfbQH8BHwNfB74F7f6+m+ZcYYYwpS27bw+efQpEmh7jbQNYKRQFdV3Zpj3g+++wk+8T2MMcYUc4GahsrkSgIA+OaVyc/GRSRRRNaJyEYReTLAer1EREUkLj/bNcaYEmnMGKhfH44fL9TdBkoEGZ3YA90AABngSURBVCJSL/dMEbkCN7RkQCISBowFbgCigH4iEpXHepWBYcB/8xu0McaUSNu2ufEIyuTrt3aBCZQIngW+FJGBIhLju3B8N+5+ghEB3pctHtioqptV9TgwBcjr2sL/A/4KHD3H2I0xpmTZudMNWl+IlUchQCJQ1Y+B3sC1wCTgX7gby+7wLTubOsD2HNOpvnl+ItIKqKuqnwbakIgM8vVcSk5LS8vHro0xphjatg1q1Sr03Z7xYrGIlFbVH4D+57ntvFKa+heKlAJeAQaebUOqOg7fsJlxcXF6ltWNMab42bwZFi2CZ54p9F0Hahpakv1CRF4/j22nAnVzTIcDP+eYrgw0BxaIyFYgAZhhF4yNMSGpVCl48EG4775C33Wg7qM5f9G3P49tJwGNRCQC2AH0Be7MXqiq+4Dq/p2JLAAeU9Xk89iXMcYUX3v3upvI3ngjKLsPOHj9hWxYVTOBIcAcYA3wvqquEpGRInLLhWzbGGNKjKwsuOoqV3U0SAKdETQVkR9xZwaRvtf4plVVW5xt43nVJVLVPHscqWqnfEVsjDElyapVsGYNLF1a6ENUZguUCJoVWhTGGBOKDh2Cu+5yr6++OmhhBKo+uq0wAzHGmJDzl7/AihXw+uvQuHHQwghYfdQYY4yHvvvOFZobMiSoYdiQk8YYEyxTp8Lu3cGOwhKBMcYUuuPHYdcuqFsXatQIdjQB7yxeQYAupPnpNWSMMSYP77wDgwbBt99C+/O5TatgBTojuMn3PNj3/K7v+X+Aw55FZIwxJZUqPPUUjB4NMTHu/oEiIFDRuW2+nkPtVfVxVV3hezwJdCu8EI0xpgSYPt198b/0EvTpA7NnF3qV0TPJT6+hiiLi7+AqIlcBFb0LyRhjSqBmzeDoUTf4zL/+BeHhwY7ILz8Xi+8BJorIJbhrBvtwYxgbY4zJr2bNYNmyYEeRp7OeEahqiqq2BFoAsaoaq6pLvQ/NGGNKgHffdUlg8eJgR3JGZ00EIlJTRN4CpqrqPhGJEpF7CiE2Y4wp3j7+GO6+G37+GRo0CHY0Z5SfawSTcBVEa/um1wOPeBWQMcaUCHPmQL9+rnfQunVF4n6BM8lPIqiuqu8DWeAvL33C06iMMaY4W7kSEhOhUSP4/HM31kARlp9EcEhELsV3c5mIJOAuGBtjjMmmCvPmudfNm8Pbb7sbxmrWDG5c+ZCfXkN/AGbgxiT4DrgMN6i9McaEtqws+P57eP99mDvXNQElJUFcHAwcGOzo8i0/iWAV0BFoghuUZh35rFoqIonAGCAMmKCqL+Va/gDuzuUTwEFgkKquznf0xhgTLDt3Qrt2sH07lC/vrgX89a/QunWwIztn+UkEi1S1NS4hACAiS4GARysiYcBYoCtuIPskEZmR64v+P6r6D9/6twB/BxLP7RCMMaYQJSW5L/3LL4du3Vwy6NMHKlcOdmTnLVDRucuBOsBFItKKk4PZXwxUyMe244GNqrrZt70pQA/AnwhUdX+O9StygeMkG2OMp1asgPh4N7Rk06YwfnywIyoQgc4IugEDgXDgb5xMBPuBp/Kx7TrA9hzTqUC73CuJyGDcdYiywLV5bUhEBgGDAOrVq5ePXRtjTAH57TeYORP+8x/46quT80qQQEXn3gGuAx5Q1WtVtbPv0UNVp+dj23lVUzrtF7+qjlXVSOAJ4M9niGWcqsapatxll12Wj10bY0wBGTnSXfhdvhyGDYPNm4tM1dCCEvCir6pmAfef57ZTgbo5psOBnwOsPwW49Tz3ZYwxFy4z090I1r8/TJ7s5g0dCv/9L+zYAX/7G0REBDdGD+Sn988XIvKYiNQVkWrZj3y8LwloJCIRIlIW6IvrhuonIo1yTN4IbMh35MYYU1B27oRHHoFatdyNYDNnwlJfSbXISHddoHTJHdAxP0eWXWl0cI55CgQsnKGqmSIyBFeeIgyYqKqrRGQkkKyqM4AhItIFyAD2AAPO9QCMMea8qJ4cD+D++2HWLLjxRlcbqHt3KFcuuPEVIlEtXh114uLiNDk5OdhhGGOKK1V47TUYOxY++giio2H1aihbFho2DHZ0nhGRFFWNy2vZWc8IRKQM8CBwjW/WAuCfqppRYBEaY4zX9u2Db75xF3+Tk6FDBzhyxC2LigpubEGWn6ahN4EywBu+6bt88+71KihjjClQR4+6O343b3a1f1591fUAKiJDRQZbfhJBW9/ANNm+EpEfvArIGGMKxKJF8Oij8OmnUL06TJ0Ke/a4rp8VbbTdnPKTCE6ISKSqbgIQkQZYGWpjTFGUng4vv+yqgCYnuwSwc6d7jsuzedyQv0TwJ2C+iGzG3SR2BXC3p1EZY8y5OnrUDQmZluaagV55BQYMgKpVgx1ZkXfWRKCq83z9/bOrj65V1WOeR2aMMYFkZcG0ae4C8JgxrgLo3/7mkkB0dLCjK1YCFZ1rC2xX1V9U9ZiIxAK3A9tE5DlVLVnFNowxRd+JE67ez3vvufr/O3e6BPDAA24wmLvuCnaExVKgO4v/CRwHEJFrgJeAf+FGJxvnfWjGGONz/Lh7Tk93N3t98on75T9mDOzd65KAOW+BmobCcvzq7wOMU9UPgQ9FZLn3oRljQt5PP8GoUbB+PXzxhRsAft48V/KhfPlgR1diBEwEIlLaN1j9dfjKQOfjfcYYc/5++w0++wy2bIGXXnJnA/fee7IkxDXXnH0b5pwE+kKfDHwtIruBI8BCABFpiA1eb4wpKAcOwPz57td+QgIsWQK/+51b1qGDGwQ+MjK4MZZwgcYjeBH4IzAJuFpPFiUqBQz1PjRjTIl1/Dh89x3cfLNLAD16wOzZbtm117p7ANLTXY8gSwKeC9jEo6qL85i33rtwjDEl0qFDrpfP9de7u3qvuw6+/dYtu/deuPNOaNPGTZcte/K1KRTW1m+M8Y4qTJoEzz4L27fDtm0uEbz5pvvV36ULhIcHO8qQZ4nAGFPwDh+Gp55yI3stXgzt2sHrr7uBX8B197Qun0WGp4lARBKBMbiBaSao6ku5lv8BV8U0E0gDfq+q27yMyRhTgH77zVX0XLLE3ehVs6ar81+hgmvfP3rUlXoYNgxK5WdARBMMniUCEQkDxgJdceMXJ4nIDFVdnWO1ZUCcqh4WkQeBv+LuWTDGFEXHj7s2fIB+/WDKlJPLwsPdNYBs2UM9miLPyzOCeGCjqm4GEJEpQA/AnwhUdX6O9RcDv/MwHmPMuVCFpCRXvnnfPti40f3yT02FatWgTx9X06dpU3eXb0SE1fcvprxMBHWA7TmmU4F2Ada/B/gsrwUiMgjfDW316tUrqPiMMYHMmQM33ABhYa7Jp1o1V8vnmK/m5K23uocp9rxMBHn9NMhzgGQR+R0QB3TMa7mqjsNX3yguLq54DbJsTHGQlgZvvOHa9UuXdkng2mvdzVzdup28yGtKJC8TQSpQN8d0OPBz7pVEpAvwNNDRylsb4zFV14Wzfn03/cIL8I9/wM8/u2V168LdvuFGypaFgQODFakpRF4mgiSgkYhEADuAvsCdOVcQkVa4KqeJqvqrh7EYE7rS0mDmTJg1y7X5b98O06dDz57uV//mzVCvnmsGio+3dv4Q5FkiUNVMERkCzMF1H52oqqtEZCSQrKozgJeBSsAH4v7x/aSqt3gVkzEhIyMDypRxz+3auQJulSpBYiI88cTJYRuvuso9TEjz9D4CVZ0NzM41b0SO11283L8xIWf3brjxRjdI+/r1Lhnceqtr57/uOtf+b0wu9q/CmOJuzx545hnXbz8pCTIz3Yhd2f7+9+DFZooFu9XPmOLmm29c1c7x4930rl0wcaK7c/fhh10NnzffDG6MplixMwJjiov0dPjnP92v/5o1XRMQuDLN6elw0UXBjc8UW5YIjCmKtmyB5cvhpptcO//LL7sibpmZ0LkzfPghVK3q1i1Txj2MOU+WCIwpCo4ccQO1zJoF06a5Mg7gCrl17gzt28Mf/uBG7oqJCW6spsSxRGBMMGRlubo9lSq5csybNkHXru4mrhtugD/+Ea6+Gho0cOtbN0/jIUsExhSWw4fh44/dzV2zZ8P+/fA//wP//rcr3jZnjruhq0qVYEdqQowlAmO8kJkJO3a4L/xBg1zhtt693XT16nD77a7JJzHRrS9yaglnYwqRJQJjCkpGBnz6qeu6uWgRHDzo5t9zj0sE/fvD0KFueEa7scsUIfav0ZjzoQo//ghffOGac665BjZsgNtuO1msrUUL96s/eyCXPjbmkimaLBEYk18nTriyzKtWuQSwapWb/9hjLhHUqgUffeQKuV18cXBjNeYcWCIw5kzS093F3cOHXZNOWBiMGeN6+LRu7cbm7dED6tRx61etagO1mGLJEoExOaWluXINkya5om1ZWW5krsGDXQmHBQvcF74NxG5KEPvXbEJXVhYsXAiPPOLq84C7gevJJ10z0NNPu0Juu3ef/OK/9FJLAqbEsTMCE3rmzIH333fPO3ZA+fLQsqWr0X/NNbBmDTRubF/4JmRYIjAll6pr358+HZYtO1mO+b774NdfoVMnGDXKtfNXquSW1apl4/OakONpIhCRRGAMboSyCar6Uq7l1wCvAi2Avqo6zct4TIhISXEXdRcuhK1b3bz27V1iEIEPPnBnAOXLBzVMY4oKzxKBiIQBY4GuuIHsk0RkhqquzrHaT8BA4DGv4jAlkKobgGXfPte0s3mzu5FryhTXpPP99zB3ruvff++90KQJ3HLLybF427ULbvzGFDFenhHEAxtVdTOAiEwBegD+RKCqW33LsjyMwxRX69bBDz+4X/Y//wzdu7u7dDdtOv3LPD7ejdQFrqTDkCE2CLsx+eRlIqgDbM8xnQqc108xERkEDAKoV6/ehUdmirYTJ6BuXdi5001XqABXXHFyIJbq1eEf/4BmzaB2bdePP+egLOXKFX7MxhRjXiaCvH6O6flsSFXHAeMA4uLizmsbpojKbuZ59113Qfebb9yNWw884L7w27VzlTlztudXqQL33x+8mI0pYbxMBKlA3RzT4cDPHu7PFCfbt8OLL8L8+e7GrXLloEMH17xz6aUwYkSwIzQmZHjZUToJaCQiESJSFugLzPBwf6ao2rTJDbR+773w+edu3po18N57rslnwgQ3APsXX7gkYIwpVJ6dEahqpogMAebguo9OVNVVIjISSFbVGSLSFvgIqArcLCLPq2q0VzEZD+3ZA2vXurb62FjX5HPdde4L/5df3DqXXuqGWUxMdKNv7d5t7fnGFAGe3kegqrOB2bnmjcjxOgnXZGSKo2XL4LPPXLv+V1+5evwNGrgzABGXEOrVg4gIN+hKu3Yn79atUCG4sRtj/OzOYhPYoUOuzv6hQ+6Lf+lSN/BKuXKuaedvf3P99B9+2N2pm7P8cvadvMaYIk1Ui1cnnLi4OE3OLhBmCl5mpnsuXdr92r/5ZtedM9tll7l2/tatXbv+iROuC6cxpkgTkRRVjctrmZ0RhLKjR2HaNNd9c9MmSE11g6288oq7IatNG7j7bujaFSpXdt0469Y9eaNWzZrBjd8YUyAsEZR0J064L/h161zZhR9+cHV2Ro92yx94wJVjbtTI3Zh1/fXQsKFbVqOG6+1jjCnRLBGUNKtWwZYtcNNNbrpNG/flD27s3NjYk+345cu7cXfDw0+Oq2uMCTmWCIo7VXcxd9Ys+M9/3AArlSvD/v1u+TPPuG6akZHQti1ccsmp72/QoPBjNsYUKZYIipsTJ9yduFWrwuWXw7/+BQMHumXR0W5UrdtuO7n+7bcHJUxjTPFhiaA4WLTI/dL/7DNYssQNqv6//wvDh8MNN8Abb0CXLq6d3xhjzpElgqJAFZYvh40bYds2d4NW1arwzjtuec+erqvmFVe4L/5rrnHP4C7oPvhg8GI3xhR7lgiC5fBhd1NWWBj07g0ffnhyWWQk9Ot3cvqDD1wlziZNbBxdY0yBs0RQGFTdGLmbN7v++t9/D1Onujo8NWrAHXdAt27uYm54uKvJk3NQlQ4dghe7MabEs0TglQMH3K/9ChXg229dc042ETeiVrY77ij8+IwxxsfaGQpSWporqXzNNa6b5lNPufnt28Nrr8HMmbBypRtrd/FidzZgjDFBZmcE52vPHtc/P7unTo8ebgD1rCzXN//BB0+eBZQqBUOHBi9WY4wJwBJBfv3wgxtNK3sAlZQUV5jtt9/cDVwDB7pCbDfd5O7eDQsLdsTGGJMvlgjO5JdfYMEC96u+dm1XgvnRR92ytm3hhRfcL//s6q09e7qHMcYUM54mAhFJBMbgRiiboKov5VpeDvgX0AZIB/qo6lYvYwpo+3bXVXPmTPj6a/clP2YMDBsGffpA9+7Wrm+MKXE8SwQiEgaMBbriBrJPEpEZqro6x2r3AHtUtaGI9AVGAX28iglwNXhSU2HhQli9Gpo2PXlDVps27oJvkybw7LPubt2EBLfsoovcwxhjShgvzwjigY2quhlARKYAPYCciaAH8Jzv9TTg/0RE1KvRcgYOPHm3Lrgv9sTEk4ngL39x7fytWnmye2OMKYq8TAR1gO05plOBdmdaxzfY/T7gUmB3zpVEZBAwCKBevXrnH1F0tKvRU7OmG1Yxd/nle+45/20bY0wx5WUikDzm5f6ln591UNVxwDhwQ1Wed0R/+tN5v9UYY0oqL28oSwXq5pgOB34+0zoiUhq4BPjNw5iMMcbk4mUiSAIaiUiEiJQF+gIzcq0zAxjge90L+Mqz6wPGGGPy5FnTkK/NfwgwB9d9dKKqrhKRkUCyqs4A3gLeFZGNuDOBvl7FY4wxJm+e3kegqrOB2bnmjcjx+ijQ28sYjDHGBGZF54wxJsRZIjDGmBBnicAYY0KcJQJjjAlxUtx6a4pIGrDtPN9enVx3LZdQoXKcEDrHasdZsgTjOK9Q1cvyWlDsEsGFEJFkVY0LdhxeC5XjhNA5VjvOkqWoHac1DRljTIizRGCMMSEu1BLBuGAHUEhC5TghdI7VjrNkKVLHGVLXCIwxxpwu1M4IjDHG5GKJwBhjQlzIJAIRSRSRdSKyUUSeDHY8F0JE6orIfBFZIyKrRORh3/xqIvKFiGzwPVf1zRcRec137D+KSOvgHsG5EZEwEVkmIp/6piNE5L++45zqK3OOiJTzTW/0La8fzLjPhYhUEZFpIrLW97leWRI/TxF51PdvdqWITBaR8iXl8xSRiSLyq4iszDHvnD9DERngW3+DiAzIa18FLSQSgYiEAWOBG4AooJ+IRAU3qguSCfxRVZsBCcBg3/E8CcxT1UbAPN80uONu5HsMAt4s/JAvyMPAmhzTo4BXfMe5B8geY/QeYI+qNgRe8a1XXIwBPlfVpkBL3PGWqM9TROoAw4A4VW2OK0/fl5LzeU4CEnPNO6fPUESqAc/ihvWNB57NTh6eUtUS/wCuBObkmB4ODA92XAV4fJ8AXYF1QC3fvFrAOt/rfwL9cqzvX6+oP3Aj280DrgU+xQ1vuhsonfuzxY19caXvdWnfehLsY8jHMV4MbMkda0n7PDk5Rnk13+fzKdCtJH2eQH1g5fl+hkA/4J855p+ynlePkDgj4OQ/wGypvnnFnu90uRXwX6Cmqu4E8D3X8K1WnI//VeBxIMs3fSmwV1UzfdM5j8V/nL7l+3zrF3UNgDTgbV8T2AQRqUgJ+zxVdQcwGvgJ2In7fFIoeZ9nTuf6GQblsw2VRCB5zCv2/WZFpBLwIfCIqu4PtGoe84r88YvITcCvqpqSc3Yeq2o+lhVlpYHWwJuq2go4xMkmhLwUy+P0NXH0ACKA2kBFXBNJbsX988yPMx1bUI45VBJBKlA3x3Q48HOQYikQIlIGlwTeU9Xpvtm7RKSWb3kt4Fff/OJ6/O2BW0RkKzAF1zz0KlBFRLJH18t5LP7j9C2/BDcEalGXCqSq6n9909NwiaGkfZ5dgC2qmqaqGcB04CpK3ueZ07l+hkH5bEMlESQBjXy9E8riLlDNCHJM501EBDfe8xpV/XuORTOA7F4GA3DXDrLn9/f1VEgA9mWfrhZlqjpcVcNVtT7uM/tKVf8HmA/08q2W+zizj7+Xb/0i/wtSVX8BtotIE9+s64DVlLDPE9cklCAiFXz/hrOPs0R9nrmc62c4B7heRKr6zqCu983zVrAvrhTiRZzuwHpgE/B0sOO5wGO5Gne6+COw3Pfojms/nQds8D1X860vuF5Tm4AVuF4bQT+OczzmTsCnvtcNgCXARuADoJxvfnnf9Ebf8gbBjvscji8WSPZ9ph8DVUvi5wk8D6wFVgLvAuVKyucJTMZd+8jA/bK/53w+Q+D3vmPeCNxdGLFbiQljjAlxodI0ZIwx5gwsERhjTIizRGCMMSHOEoExxoQ4SwTGGBPiLBEYcxYicrmITBGRTSKyWkRmi0jjAOsf9D3Xz1mJ0piiyhKBMQH4bnz6CFigqpGqGgU8BdQMbmTGFBxLBMYE1hnIUNV/ZM9Q1eWqulBE/iQiSb568s8H2oiIRIvIEhFZ7lu/keeRG5NPlgiMCaw5rkLmKUTkelwt+XjcXcFtROSaANt5ABijqrFAHO7OU2OKhNJnX8UYk4frfY9lvulKuMTwzRnWXwQ8LSLhwHRV3eB9iMbkj50RGBPYKqBNHvMF+IuqxvoeDVX1rTNtRFX/A9wCHAHmiMi13oRrzLmzRGBMYF8B5UTkvuwZItIW2A/83jcmBCJSR0RqnGEbiEgDYLOqvoarPNnC27CNyT9rGjImAFVVEekJvCoiTwJHga3AI8BeYJHrWMRB4HecrDefWx/gdyKSAfwCjPQ4dGPyzaqPGmNMiLOmIWOMCXGWCIwxJsRZIjDGmBBnicAYY0KcJQJjjAlxlgiMMSbEWSIwxpgQ9/8BJqCRfldGrysAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "legend_label=\"SCOT alignment FOSCTTM \\n average value: \"+str(np.mean(fracs))\n",
    "plt.plot(np.arange(len(fracs)), np.sort(fracs), \"r--\", label=legend_label)\n",
    "plt.legend()\n",
    "plt.xlabel(\"Cells\")\n",
    "plt.ylabel(\"Sorted FOSCTTM\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "##### Visualize Projections"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXwAAAEICAYAAABcVE8dAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOy9e5wcVZn4/T1VnRCmuyvIQkYCCgSJkmSSzmRCZwg94aYI+CYozi7ioqLo+uJ6Ydfru/6ExXVV9Cfq/sDV9e6+gA4icRVfXBAyExLGZMKECUFDjLgQmElAk7mEZGa6n/ePquqprq7qy0zPdM/M+X4+9elLnT59qrvqqec857koEUGj0Wg0Mx+j2gPQaDQazdSgBb5Go9HMErTA12g0mlmCFvgajUYzS9ACX6PRaGYJWuBrNBrNLEELfM24UEpdoJR6rha+SyklSqnXTMVYCozhGaXUJVX43u8rpf6lCt/7K6XUO6f6ezUTQwv8WY5S6hql1Hal1KBS6gXnQj6/2uPS1DYicpmI/KDa49CUhxb4sxil1D8AXwX+FagHXg3cAWyY5O81J7N/jUYTjBb4sxSl1HzgFuADInKviAyJyIiI/JeIfMxpc5xS6qtKqeed7atKqeNC+jtHKfWIUuqQUupJpdR6z77vK6W+oZS6Xyk1BFyolFqolPqpUuqgUuqPSqkPedof73zmL0qp3cDqEg7pcqXUPqXUi0qpLymlDKevs5RSv1FKveTs+3+VUid4vusTSqn9SqkBpdTvlVIXO+8bSqlPKqX+4Hz2J0qpEz2fu1Yp9Sdn3z8V+62VUj90jvVPSqlPe8b3LqXUZqXUl53j/aNS6rICfa1USu1wxvtjYJ5v/3uVUnuVUn9WSv1cKbXQs0+UUjcopZ52Pv9Z5/fZqpTqd45xrtP2FUqpXzhj/ovz/DRPX48opa4v5Ric/fuc7/yjUurtRf5LzWQhInqbhRvwRmAUiBRocwvwGLAAOBnYAnzW2XcB8JzzfA6wF/h/gLnARcAA8Fpn//eBw8BabCWjDugCPuO0XwTsAy512n8B6ABOBF4F7HK/K2ScAjzstH81sAe43tn3GuD1wHHOMbQDX3X2vRZ4FljovD4DOMt5/hHn2E9zPvtN4C5n3xJgEGhx9n3F+S0vCRnfD4GNQNz5jj3Ae5x97wJGgPcCJvB/A88DKqCfucCfgBud3/ytzmf/xdl/EfAi0OiM69+Adt/v9HPAApYCx4CHnN9/PrAbeKfT9q+Aq5z/Kg60Afd5+nrE8xuHHgMQBfo958IpwNJqn/+zdav6APRWpT8e3g70FmnzB+Byz+tLgWec5xcwJvBTQC9geNreBdzsPP8+8EPPviTwP77v+hTwPef5PuCNnn3vo7jA97a/AXgopO2VwOPO89cAB4BLgDm+dk8BF3ten+IItQj2jepuz74oMEyAwHcE4DFgiee9vwMecZ6/C9jr2VfnHM8rA/pqwXczwL4JuwL/O8Ctnn0xZ8xneH6ntZ79XcAnPK//N87NMOC7E8BfPK/9Aj/wGJzf5hD2zeP4ap/3s33TJp3Zy0vASUqpSIE2C7E1Spc/Oe8FtXtWRDK+tqd6Xj/reX46sNAx/xxSSh3Cnh3Ue/vz9VUMf/uFAEqpBUqpux2zTT/wn8BJACKyF1uTvxk44LRzj+904Gee8T0FpJ0x5oxPRIawf88gTmJMM/eOz/vb9Hr6OuI8jQX0tRDYL45U9fTl3Z99LSKDzri839Xnef5ywOsYgFKqTin1TccE1Y89MzqhwPpL4DE4v83fAO8HXlBK/VIp9bqQPjSTjBb4s5etwFFsjTeM57EFn8urnfeC2r3KtUt72u73vPYKqWeBP4rICZ4tLiKXO/tfwDblePsqhr+9O87PO9+9XEQs4G+xTQ32oETuFJHzsY9TgC96xniZb4zzRGS/f3xKqTpsE0gQL2Jr2f7fcX9w84K8AJyqlFKe97y/Tc7/pZSKOuMaz3f9I7bJK+n8bi1ut+V2JCIPiMjrsWdJvwP+Yxzj0VQALfBnKSJyGNs0cbtS6kpHo5ujlLpMKXWr0+wu4NNKqZOVUic57f8zoLtOYAj4uNPHBcD/Bdwd8vW/BfqdBdPjlVKmUmqZUspdnP0J8Cln4fA04IMlHNLHnPavAj4M/Nh5P45tbz+klDoV+Jj7AaXUa5VSFyl7Ifootoabdnb/O/A5pdTpTtuTlVKu99I9wJuUUuc7i5y3EHItiUjaOZ7PKaXiTn//QPDvWIyt2GsFH1JKRZRSbwHO9ey/E7hOKZVwjulfgU4ReWYc3xXH/j0OOYvVN42jD5RS9Uqp9c7N5xj2f5Eu8jHNJKEF/ixGRL6CLXw+DRzE1mr/HrjPafIvwHbgCaAH2OG85+9nGFgPXIat0d4BvENEfhfyvWnsG0IC+KPzmW9jLxwC/DO2aeKPwK+BH5VwOBuxbdLdwC+x7dluX43Yi8a/BO71fOY47AXiF7FNEguwTUsAX8Ne4Py1UmoAewE36Yz/SeAD2AL2BeAvQKEgtA9i3xD3AZudz323hGPKwfmd34JtM/8LtqnkXs/+h4D/BfzUGddZwNXlfo/DV4HjsX+bx4D/b5z9GNizheeBPwPrsNdYNFVA5ZoDNRqNRjNT0Rq+RqPRzBK0wNdoNJpZghb4Go1GM0vQAl+j0WhmCYWCbqrKSSedJGeccUa1h6HRaDTTiq6urhdF5OSgfTUr8M844wy2b99e7WFoNBrNtEIpFRqZrk06Go1GM0vQAl+j0WhmCVrgazQazSxBC3yNRqOZJWiBr9FoNLMELfA1Go1mlqAFvkZTgL6+PlpaWrAsi5aWFvr6+op/SKOpUbTA12gK0NraypYtWxgYGKCjo4PFixdroa+ZtmiBr9EUoLu7m3R6rF5Hf38/ra2tVRyRRjN+tMDXaAqQSCTy3uvu7q7CSDSaiaMFvkZTgLa2NizLyr6ORCKBNwGNZjqgBb5GE4C7WHv22WdzzjnnkEwmicfjNDc309bWVu3haTTjQgt8zaylr6+PNWvWEIlEME2TNWvWZBdkW1tb2bp1KwMDA3R2drJt2zYSiQRtbW3U19dXeeQazfjQAl8zK+nr62Px4sV0dnaSTqfJZDJ0dnZmF2S7u7sZHR3Nts9kMnR0dLBhw4ZqDVmjmTBa4GtmJa2trfT39+e97y7IJhIJIpH87OHbtm2b9LFpNJOFFviaWUmYp427INvW1kZzc3NgGx2IpZmuaIGvmVW4i7FDQ0N5++rq6hgaGsKyLFpbW2lrayOZTOa1+8OWLfxiYIBfdHTQu3gxhAh9HaWrqTWUiFR7DIE0NTWJrnilqSSu3T7IlOMnEonQ3NzMHXfcQSKRyAm+6gGWAgoQ4AiwIhbj2//1X3zmM5+hu7ubRCLB8PAwXV1djI6OZvtrb2+fpKPTaGyUUl0i0hS4Twt8zWyhpaWFjo6OktvHYjEMw8i5QbQAj2ALexcBOoCLTBOlVFbAZzIZMplMtl08Hi/pZqPRTIRCAl+bdDQzkiBzSpDd3jTNwMXZSCSSJ+wBHgr4LgUkgHQ6nfXsGR0dRSmV7VsHbGlqAS3wNTMSrx/91q1b2bBhA0qpvHbHHXcczc3NxGKxrEZvmiarVq3KMeMALABMcrV7sDX8bnJvHpFIhKamJpqbm3XAlqZm0AJfMyPx+tGPjo6yfft2jhw5ktMmEomwatUq2tvbWblyJUePHiWTyWRvDKZp5rQPEteuQXSeYbDpJz/JEfAbN26kvb2d/v5+2tvbdcCWpurkz2U1mhlAIpFg69atjI6OYppmnrYO5Gjd/hvEtm3b8mYECfK1e/f16kwGeec7ad+7F7Rg19QoWsPXzEhcP/poNBq4v7GxkZ07d/LKV76S+fPnc/bZZ+do9JlMJu8m0Q2MOM/9rg4KUIODDOtIXE0NowW+ZkZSX19Pe3s7jY2NeYLbNE327NmTXZDt7+9nx44dgbMAL63AVmAQSGMLfa/gV8CI9izT1DBa4GtmNEGeOU1NTZw+OMghIAMcwvard1kAbAIOO48LnPcPAOuAOOCGbbm++GBr/9016uas0YAW+JoZjj8njpvbfgtgYQtsCzuYahu2cG8Dmp33mwlerHU/C2NCfytw6+rVOsJWU7NUROArpd6olPq9UmqvUuqTBdq9VSklSqnAoACNptK4tvx4PE4qlWLPnj1kenqIkyuwFbAKeBo4D5jj7JuDvVjrxZ0NiO/x75XiWxs35rmE6pKImlphwl46SikTuB14PfAcsE0p9XMR2e1rFwc+BHRO9Ds1mlJxbflgB2Nt2LCBB33umS4K21zjxbXTL8A26SzAXrx127uPAmwxDGL19XkeP7okoqZWqISGfy6wV0T2icgwcDcQ5KrwWeBW4GgFvlOjyaOQKWXXrl2ceuqpdHZ25mj3fpRvnwLqgI3Y9vz9BAdfKSCaTmOaZk5iNh1hq6klKiHwTwWe9bx+znkvi1JqJfAqEflFoY6UUu9TSm1XSm0/ePBgBYammU20trayZcsWBgYG6OjoYPHixVmhv3btWv4qnWZTyGf95hkvc4AkkMKeEgfdLAToh7z8OXV1dTrCVlMzVELgh53/9k6lDOA24B+LdSQi3xKRJhFpOvnkkyswNM1swNXsOzo6clwr+/v72bBhAy0tLfT392cXY4NSI7hbmOZPyD73c2lszd/r1QMgIjrCVlMzVELgPwe8yvP6NOB5z+s4sAx4RCn1DLAG+LleuNVUCneRNIjOzk62bNnCAnIXY70oxvzqwyh0I+hyPhsj36tnaGhIe+poaoZKCPxtwNlKqTOVUnOBq4GfuztF5LCInCQiZ4jIGcBjwHoR0REqmnHjtdc/+uijOfVn/fxVOs0ebA08DPdGECb0vSYff5sE+V49hmFfWplMRnvqaGqGCQt8ERkF/h54AHgK+ImIPKmUukUptX6i/Ws0QXhdH702c3/CswXAHnL95sPwBlG5uAJ+EBgAngj4DIylXBgBegwjJ6WD9tTR1AoV8cMXkftFZLGInCUin3Pe+4yI/Dyg7QVau9dMFK/rI9iCPh6Pc95552W166XYXjWlCHsY89Dxp0sAOyJXgDN8+zPATuyqV271q28mEjkBX9pTR1Mr6EhbzbTEL1CbmppIJBJ0d3dTV1cH2NG0Yfnri9nr/ULf8mzeiyYDzK2rI+q0iwLfnjMnJ+BL58LX1Apa4GumJX6BCmRNPC+//DILINTfPkiT9+7zPga9782d02kYLFEqG8EYAeZ2dlLf2kp7W1tJufB1KgbNVKFr2mpmBJZlMTAwkH29CdtvvhRTznhw69i2AveaJucphfIuHEci0NwMJRQtb2lpyebu18XONRNF17TVzHiWLFmS8zqoWAkU9sIpVfVxg6xasV0wl6fTDInkfn50lMzjjxftq6+vjy1btuhUDJopQVe80sw4FhAeSBV2Eyh3JrAe2Ivte68ASafJYNv052Cbe3YbBiuK9NPa2pqXh18v8GomC63ha6Y9fX19bNu2Lfu6DTv/TZid3k8xYe966LjPH8NODOUKe7cPw3kcwE6V/JYiBVUgP1+/YRh6gVczaWiBr5n2tLa25vjiewOhShX6YQhkNfc0sN0w+EIyydpoNHD2YAK7nOdPHD0KLS1QYBHW7220du1anYpBM2loga+ZNoR5szzus5X7a88W0+CLuWiazmYA0bo6Ht69m98pFerlsxo7xUI0nYatW6FAlK1239RMJVrga6YNYYVF3ECrbDtsk0p4soV83PlB0OKt12zz2sFBBgYG6B8cDOxHsC+q7OLY6Ch4zTZ9fQyvWcNQJMKjpsn7NmygrUT3TY1momiBr5k2hBUW8S96urVnj1Gap06YgC/E0pB2Cvvm4c4wRgG8i7CtrRidnUTTac7NZPhoZ6fOs6OZMrTA10wbwtIVNDY25rVdgL1wWyi4Cs9+w7PPnxvf++jWyvKbjbzBWNuwZxj92NG+eM003d1Z7X8OsILgQusazWSgBb5m2uC1d69atYrh4WEsy2J4eBilcvVtV8SWkjAtLGmaP+rWWw3LNRtlPPvcz1yJPcOY7zziNdMkEllT0wj2jUMppaNrNVOCFviaaYNbn7a/v5+5c+fS1dXFwMAAXV1d+CPGwwKvgggqaxj02RHAXR52zUbetu4Cb0Ha2sgkk1nXzVbsnPnarKOZCrTA10xL/PZ8P09S3Fbv9a0v1FawbfGPAe9yErO59Ad8dg9wGDu9Q94SbH09cx97jFPjcdZh3zjS6bQ262imBC3wNdMSvz2/sbExLxe+nyCtfRTYgZ3v3p8h0xX0Xdh2+QTwo6NHc0oYrg34nJtVsxn4VSxW0vh1dK1mKtACXzMt8fuv33///ezfvx/LsgC7pmYhk45rb/cuxAa1fxlYjF2XMw4kM5mcEoZPAj2WZSdLI9f27y7KljJ+7X+vmQp0tkzNjKKvr4+FCxfy50wmW/ikWPBVUMET/z7v+0OGwXylEBFWr17Nf33725x8ww22v71ScOSI7X9fRsZMjaZSFMqWqZOnaWYMfX19tLa2opTK5rWB0jT9MIJuAHtjMfbv2ZMbJOUK9b4+O7K2u9v2v9eau6aG0CYdzYxhw4YNdHR0kE6n2UXxHDrlZsl00yJf7njVBKZ6qK+3hX9/v/2oI2c1NYQW+JoZgzdjph9/EBWUnmPHDax6DNue/7zjVROW6oG+PjtpmmUVTZ6m0UwlWuBrZgze4KtCqQ+8+N0vvRGzacZmAaPOdoAxr5qwVA+0ttpJ0wYGiiZP02imEi3wNTXHeGu8NjXZ61TeAigQbrrxv68870cgZx1gDtBomjleNaGuld3d9qIt5CdPq+DxajRlIyI1ua1atUo0s5NUKiWRSEQAiUQikkqlSvpcb2+vmKYpm0CGQQQkAzICknZeu+9lPK+97/sf3edpEEkm874vlUpJPB6XVColvb297gGIRCJ2v5GI/XoSjlejCQLYLiFyVWv4mpoj1FQSgqshn3322USj0bwCKABDjGn9XUBPXV02p40baVsod44C9jzxBGvWrMlq4kA21UNOauO2NtsdMx63H4t46pR7vBrNeNECX1NzlBuF6l08HRoaosc0yXj2m0CUMZ/8BHDkyBF2Ywt7xZi9PgwFvObll+ns7MxfpPVTpqeOjrrVTBVa4GtqjnKjUL0acjqd5h3z5uWc2G69WRgrTnIu0MCYFm8SXPzEi9fePzo6yqOPPoplWWxYs4bhNWvG7ZWjo241U4WOtNVMe1paWti6dWtW6JumybF0OidzZamlDruAVc5rb5SuYBcnPxs79XICO7VxK3APdt6cCOjoWk3VKRRpqzV8zbTH1ZBfqRSbgD+n01mbvUuxYuZuUNVqYKFSPGFZDDFm6hnAzoK5HzifseRobdj5ckJLGmo0NYQW+Jppj5snf6NSWWEclKMyqNKV9/VawLIsul94gRWHDzPY28v5ySQGtjbvCnb3opkDnIddWSu7ZhCJ5JY01GhqCC3wNdMe10unMZPJsdVDsFYfVLowg5NDXyQnR049dl77FGOePy4ZcguWpyHrlaN96zW1iBb4mmmPm0MnCNeU4xXuA5597qMJtAMvHDmSXXhtbW3lU52dnE+uScjNk+8KfJzHIch65YSmXdBoqogW+Jrph5OrJhOPs3P+fP7Y2QnYRUpc04rfr9610XcAu33duYJ8DRBNp7PpELq7u2kit8C5234bdoFyt5C5W5/WRfvWa2oRLfA10w8nV40xOMiS/v5sQZIrgc0Ee+QoxrxqlhCcUiFrshkdhR07Qv3hDexcPW4h837n8V11dVnTjd+3fsmSJdrEo6k6WuBrph+eXDVzsF0kYayweAfkBF65N4BmbE+bOvJt+36TzeDRo+zYsYMdhpEza4Axbf5Fw+BCw2C+873PDg9nTTd+33pAm3g0VUcXQNFMPxIJ2+wyOppjSjEMg0sTCeY9/jgZJ77Emx5hDuRUwfKSZwJKpxkaGuLNpsn9lsWKdJqho0eRdJrHsbX7TCaT08eJo6N8/tFHwbKoTyRob2vLRtlalqVNPJqqozV8zfTDyVWTiUY5Zpo0At2WRe/OnXx+715WihBhLGWCa2cPsuu773vbjQCPO8+fT6dZm07D4CAL6+qwsLX5AwHDuge75m1QWmSdPkFTC2iBr5l+OLlqRpctY146TQxY2t/P/OuvZ1F/f07iNNN5HMC2tXuFv7v1AxeTa4/3GlxM047Z9Qpt7z7LsojH4zSaZmgAlk6foKkFtMDXTFtGtm3LCtiI83qfZeVF2JrYGvsS0+SYYWQ1fXeLA1/A1tz/KhLhQsPI0eBd040rtKPRKJZlEYvFOO+889izZw/9/f1EzzvPDryCvAAsNzgsL7OmRjOFaBu+ZtqyI5NhDbZtfgToymR41+gojzNmq8d5TACvampCbduWlwbZwE6pYJomzc3NDA8P09XVxejoKJFIhJUrVwJjQjuUtjZdwFxT02iBr5m2/LVS/FgkJ5HZgSNHWIztjeMK/Qy2Z843n3qKJ4GV5EfNAuzfv596YHjDBkZE6DYMbl21im+VKrjdtMgaTY1SEZOOUuqNSqnfK6X2KqU+GbD/H5RSu5VSTyilHlJKnV6J79XMbk4/91zWQdYt0jXDHMAuNt4B2SInEWBJfz/RujqOkF/L9phhUA/Q2srcri6i6TRrDYONc+dq84tmxjBhga+UMoHbgcuwY1reppRa4mv2ONAkIsuxnRlunej3ajQbN24klUoRj8exLAvDGDudXzJNLjQMjpCb7OwcIGKaeYFXdZkMnHoqbNlSsB6tzpGjmc5UQsM/F9grIvtEZBi4G9jgbSAiD4vIEeflY8BpFfhezSzHuxC6Z88eYrGxHJlKKRKJBD2mOeaZY5oYK1fai6ummdOXAkin7c0lIPNltXLk6BuNphJUQuCfCjzref2c814Y7wF+FbRDKfU+pdR2pdT2gwcPVmBomplIkPCrr6/HW8xndHSUnTt38tfAdpxkZ+k0DA/DHXdANBr+BYYRWo+2WjlydDI2TSWohMAPKiQUWGtCKfW3QBPwpaD9IvItEWkSkaaTTz65AkPTzETChJ8/uElEeD6dZgT7hDQBurrghhvyomSzJ6xpwtq1ofVoqxVA1d3dzYmjo2wCXnIjerWWrymTSgj854BXeV6fBjzvb6SUugT4J2C9iByrwPdqZilBWnZfXx/Dw8NZQZ7JZKirq8M0TRL4EqN1d9NjGIERuESjBd0pxxNAVQlzTCKRyJZStHAierWWrykXEZnQhu0AsQ84E5gL7ASW+tqsBP4AnF1qv6tWrRKNJohUKiWRSEQAiUQiclljo2w2TTkMsglkgRNEG4lExLIs2WwYMgIiIBKJiKRSsigalU0gGfd9Zxs0TYnH45JKpaS3t3dSxptKpcruo7e3VwZNM2esEo9XZHyamQWwXULk6oQ1fBEZBf4eeAB4CviJiDyplLpFKbXeafYl7KpzbUqpbqXUzyf6vZrZi1/L/tyePZybTufUmQVb+xcR1j7/PJFk0jbXZDIwPMyyZcu4OBKhg7F0C6NAVzrNwMAAHR0dvOY1r8nVyp08/FhWtkhKKVTC7l8PHH/88VnT0ygwvMTvDKfRFCHsTlDtTWv4mlLp92npI46Wn6NNp1K2du9o+ceSSbEsSxY4swL/7MC7Zfvx9gEiliUHenoklUoVnBVUQsOXVCo7S8mAHAJZn0xO8JfTzEQooOFXXbCHbVrga3p7e8OFaW+vLYDjcRkwTUl7BH7aEd7JZHLsM/F4njkkHo/nCXccoe+/CcTj8fw+QLotq6gwL3gcpeL77sPumDQaH4UEvk6epqkKpSxkFnRFdKpeMTBAlFxXMQM7d87cuXPt6NmWFjhyZKyB41/v97hx/fjbGFscbQY2Ah1K5fbhsKi/v6i5piKJ0xKJbNTwCPZCmU6xrCmbsDtBtTet4c9sSjFzuBq4q3H3g63V9/bmabyjIMPO82GnfTwezzPDZEAGTFNW19VJMpmUZDKZ1bx7HPOM30Q06piJ3M9nF3pNM0/DTyaTE9fmg+jtlWPJpAyapmw2DFnvnb1oNB7QJh1NreE3pwSZJ9ybwiaPMHcFrViW/eja5H2eOgtN076JBJhh0o4Abw+zg/vs/aMBNwBxbiZ+G34ymZy4vV6jmQBa4GtqjlI0fNf27de4s+6VlpUVvNLbG2wr9y+0erZhZ/HT24fzxdn1AUmlpNMwcmYPmw0j9LiK3sh8fYvW0jUVRgt8zdRRokArayEzTGiXsmjZ0zM2EwjYMt4bSIg2vj6ZlHZnoTR0VpAdasiNzP1dDCP3pqVnAJoKowW+ZurwmUMqItAKCMuinjyWFSrk/UFXYTeQcm5OoW0nctPSaMpAC3zN1BHg/lgxAmYPBU1DqVSwZh+k8ZdyA8kbThmzlIC1BK3hayYDLfA1U0clNPwy7NxBvvRZ4RskZC1LJBrNf7+UG4iPZDKZ873JQoFQfg3fNLUNXzMpaIGvmToqsShZxk3DK6C9m2VZciyZzIuMFf9Crq//sEXXIG3eNM2ctqZpTu7votGUQCGBrwOvNJXFresakl64JLq7Q6tO+QO27rjjDpqbm/O66O/vpxXsnPbxOKRSsGcPfcCG4WEezWQYMk2GV63KyY65xJOfZgGwSQQsi97Fi/nDli05QWD2tTWG/3XFfxeNZoJoga+pPRIJOxoW8qpO+aNvb7jhBtrb20mlUnndPLx7d56QbW1t5f6uLs7PZDhBKS6ZOzdU+LYBDYODMDDAkv5+7nKqYbkRtatXr85p738909FVuKYhYap/tTdt0pnFFDB/FDK5WJaVZ9bxL6T6Px+LxXJMNbFYLLvvsM/Of5jcZGq9vb2yPpmUzYYhg6Zpm5BmkammIknhNBUHbdLRlEsx7W1StbsC5o+wilP19fXs2bMHy7KybYeGhnjfhg05KY0vXLIk+3mAwcFBOjo6sjMGwzCy+3dCNn+NRCL80bJyCp/U19ezce5c1hoG0XSaOV1d7Fy8eNZovNUq96iZAGF3gmpvWsOvLsW0t2ppd8VcIf0a/GbDyEuLnEqlxDCMnHbeDJndliWLolFZn0zaWnuhhdaALJZT/ZtUC63h1yZoL52ZTUXS70DqZAYAACAASURBVPr68gpDyE8RUEounGrgF0JhVaL848/J11OOO6nH48dN2lZrv8lkUcnzTlM5Cgl8bdKZAQSlET64axc7589nQCl2zp/PwV27yurLS1Cx7moV8y5WdcpfDWtOU1PgArB3/EB+3dstW0qraNXWZnsCxWIcMwxWApuwPXyWFKpINc7qWbVERdI+a6aWsDtBtTet4ZdOkLbdbVk5Cb+6LWtcfeENZPJQNe0uzIfeXeiNRm1/+1jMft3TE7gA7B//sWQydybgBmOVMa4Rz+/tFmAp5ThGHNOT1pI1lQBt0pnZBNlS/Rkm+6GsvhZgJwobrLWI0LDUDUG5asoxzfT25ubq8fY9jnEFVqTyeh/5vuvwFNrBtSlmZlNI4GuTzgzAb8Zoa2tjn2Vli3OPAPs83it5eMwLDw4Pc/mqVdxrGDQD0XTarizlrTZVDpU2XYT56HuDtVx8QVsFqa+HtWtD/f9LGVehilR9fX3sXLyYkY4OGBhAMpnsvhGgm6nzdHnfhg18rqOD5wYG+FxHh+3JpJkdhN0Jqr1pDX9iHOjpkW7Lkn7HnHOgpye8cZCZpFAStHLSBFQ6e2bYd5ep4QdquRNJf1CkIlUqlcrz6xfTlEHTlHYCiq5PIpvLyO+vmX6gTTqaggQJ90KCuhwhXoHsmSWZIDw2/HQsJkOGUbAUoN8Mtj6ZnNRcN/F4PMcTaNhZIyh2bBPdH4Tfc2mwUA6gCqBNSFOLFviawgQJ8ELabjlCvAIafrn+3uXUy3U3v79+pdMWp1IpWWiaOb7+pdxUAo+lt1ckmRQxTRkF2VrmDOFYMpldYB4Be8HaRyWFtPbXn1q0wNcUplxTRjlCvAJZIsv1+S+nXq4rhML89SvFeAVo4LGkcvP8pz3+/4ZhFO+7hP+kkkK6VmM2Zipa4GsqyxSn+i0r77yUVy83FouJZVmy2TCyWm8tFSYJPJaAPP+HPb9PJcxTlRTSWsOfWrTA19QU5Wq75Qr8cvqvdTfU0MLsIRq+a54qZrIpZZG5UkJa2/CnFi3wNTV10ZUrTEK1zSqYiyrJuP8Tjw1fDEN2xWKy0CnGEolE8mIwAhdlfYFi7ZDzP9TS+aIpDy3wNTU1rS5XyIaOvQoLwpWkUt/tF86Bbpf+m6OvzGNgoJhmWqIFvqamFs7KFXSh2uZUuXxOEpP1n6xPJqXdEeLtIGfFYvlrFJaVp+EnnUyiE/0t9OygumiBr6kpDb9iAsGr4ZumnUNnGtWMnaz/xPv7WpYlpmnmB33FYnk2/GQyWZHx1NK5NhvRAl8zM7Uur5nCsibVj358w6t80FS5uLOIUtI/V2rGUUuzydmIFviaXKbYrXJKqIB5p9LUgqZbqhfSgZ4e6XTMPiOOOWjIMMZ1ftTCcc9mtMDX5FKBxc5awNWQo9GobDbNrAabqZFjqgVNt9RZRLdlSdpzw8x4b55hbrAhioP/Ow+EpKjWTA5a4GtySMdiOdpwOhar9pByKXEG4l2c3OJs5aQtmGymk6brd+XM2cJy7ZSqOMwQBWO6UEjg6/TIM4Ryior3GEZO6uQjL79cW5WXWlvtlMwDAwVTM3982zbWABbQhH0s84GUSE7h82oRlLa6Fgg6V/ZZFpmwD4gEv+9NSV0oFXWp7TSTT9idoNqb1vAL4582l+NhsSgazSbxOlTCYt5U4D2eUvPa+NtNZRGR6UzQzONAT4/sisVkxDHnlGTSSaVs8xljVdUCTUZaw59S0CadmYf/ojUMo2R7sfezfne9dCxWFW8e75janYXDYgLCm/XRDTCqljfMuKnCAnrRtQVnTOlYTLotSxZFo8G/W2+vdFuWHHa8gBaaZvDNdiY6CdQwWuDPQPwXrWmaWYEJdtbEMOHmFYDdlpXV0iQSkW7LqkoOFe/xLHCEd1EBUaIgqWlbehW031J/j1QqJaaTsgEQy9XgPb/7ZsOQBeX+b5pJRQv8GYj/onWjJL0XaEnCzSc0F0WjssDR2A7jCcuvwBgLjWUyhXIteMuEUgV30lJvxGEF7b03qRFnRuafmWUcc6GblK2mZ1kzjEkX+MAbgd8De4FPBuw/Dvixs78TOKNYn1rgFybsAipZuIVox6lUSto9dv0RGLfWWY6gnUyBoDX88ZFKpfIEfjwez7tJDZqmLIpGZdRnHswwlpStpv+DGcakCnzABP4ALALmYtdvXuJrcwPw787zq4EfF+tXC3ybSUslHCJoent7K1YMZFwX+STYe2tau6xh+3Zvb69YlpU/Yww6d1K5KZu9C+nxeLy2Z1kzjMkW+M3AA57XnwI+5WvzANDsPI8ALwKqUL9a4NuUKzRLFvh+U4JpBhcEn4DWOS5B6zMXhC3EaqaGkoq99/TY549P2HvTLoeuB2gqzmQL/LcC3/a8vhb4P742u4DTPK//AJwU0Nf7gO3A9le/+tWT/sNMBypZ3s8fmZr2XaBZwV5NrdN3I9KultMAn3afARl1btZeG37gbEFTcQoJ/EoEXqmA92QcbRCRb4lIk4g0nXzyyRUY2vQnkUgQiUQAiEQiJBKJgkFWbvsFQDvwwpEj2YCq923YwOc6Onh+aAgjnc4PtHEDYurrob0d+vvtx6kMYkokwDneEaAbGB0dpVsH61Sevj773Jho0J3vv1GGgdnby9p0mo2PPUZ9fT319fWuUgdU5j8tJ9hQ4xB2Jyh1Q5t0JpWgKXUhM4+7P6hGq78wRq0EXeXgzC4GTVPasV39tDY4SZRjuis06yvRDFfKeVuO+U8vBAfDJJt0IsA+4EzGFm2X+tp8gNxF258U61cL/HBKMvMEuPv5F2P7Kb2O61QvfNb0QutMoRyX0EI3hxJv0t7/NOnk3w+KFIfCcSRjw9cLwUFMqsC3++dyYA+2bf6fnPduAdY7z+cBbdhumb8FFhXrUwv8cMJ88PMKXfsuUH9k6iaQxsbGnAsv7ALT2tQMpBwNv4SbQ2jwXDJpb57Zgf988i7ouls1YzemM5Mu8Cdj0wI/nJLy6LhCPxq1i4PEYiLJpOyKxXJC4a0SI2u1NjUDCTLT9PbmVcIKUyByu8pdlM1Jj+HdnM/6zyfDMHI0/LDzrNAsQc8CbbTAn6G4J3/Bi8R3oW725dwpdoGNdVNYm9ImmBlCMplNnJbGTjltWVbRnPZ+t8uBIGHvmR343YcvaWjIycvjpmswnfw87vmktfriaIFfg1Si/J178ntTIbSDXNvYOHZx+uz2g56cO5FIpGQNv9h4SrkQJ+WmUMOBS7VM6H/hO19G8KRUCO9MNhtGjrA+FCbsHQ3fL/B3xGI5C7+bQkw7QTmktJKRixb4NUgxAVmKAA2qVzoCMuDxxsn4Lrh0LCbrPdPgnp6ewAv/QE+PdFuW9GOnvT3Q01PweEox+YQeU2+vbeM1DFvgJJOhgtsvqI4lkzWbmqBcpnKWFPpfGEagwC9owkulctaG2kEGlcrpx025PALygYYGqauryzlf/FlbDzs3DleR2QRSX2BmajrmSS38tcCvSYoJyND9Ho12VywmWwOEuv+1f5+b1OpAT0+ooO22rBwXzm7LKng83upT7U7/JR+zL3BHIFRw+wVVpdJA1AJTaa4I/S8CTDpFxxIQLDdgGIHnoXv++RdpvfmbvDcH7zno1foLbbPd1KMFfg3iNccEuUb6p7yXuWYajwbmLVQRJvTDLrp2V4iHCFp/ybt+CD+Y3l5Jx2LZ7xoBW/MOOea8i9LvAVJAcPsF1WbDmDEa/lQujHv/C692vD6ZlGPJZPFc+LmdZf8DVzAXsuFnPMfoavH9zo0gXeDc7Sdfqw9a6J3tTgVa4NcghQKkRPIF/o5YLDBfSSlbxje9drWwwDqmTjrksjT8IA094IILNVlMQMNfn0zOGBv+VGr43v8icB2nnLURp20/Yzb8wz7B7X0+AtLp2Py9wX9eYR90kxjxbFuwF3pdzyDTNLOzBq3ha4Ffc7gXXJ7QdQSlq+25GlAhM43/ovJuwyC7YjERy8rud+2sgRq+I2zLsuEHaejlCI0J2PBnkq22WscWOLPweneZZta1Nx2LyaBhyGbDkGsbG+2ZnNN+fTKZFbp+l0y/0C80A5WQfRnfc3dxdwG5s5TZ7q6pBX4N4mpz3gVXV8P3+jR794eZZ4IuHu8FsSgaDfSvztrwQ246JePvIxYbE/YVNLfMZGFfTQJnFkE3cc855qbmyBY8iURkRyyWvWkECfxSBXs5bYaxtf0t7ncahuyKxWThLNb2tcCvQfwafL9HK/ZegP4ZgF9LCgxucd53fZlDUyS7TFQw+wW++30VruakfbDzqcRNMLAP7zlRohA+zNgsYQvkZGM9HNA+6HwudZ9385uC0uQu8Mbj8VmlLGiBX4MUEl7eKfahAie7azP1zwD8Hg1FBf54fNm9nwnzlKmwhq+jffOZlJuga2IzTdvM5vGRD9Xwndfe+rauS2W3ZUnnd74TatcPEvBpp++wdukC/XhvPu5vMpuUBS3wa5BQjaO3V3Z40h8MFtCuXC+KbsuSdF1d1s7qLSw9aYIxTAP0CvYKB0VN2kU7nYK3fGNdFI0WvAlOtAiNRCIijufOkGHIIWwPHNeGn47Fsv99kOukdwY7WlcXKqgLCfW05/kwyNYiilAae43Ke8yzSVnQAr+G8BYhsSxLYrFYzoV4LJnM8Y4ZIVfzyT5aVqhgKigYKyXc/OYaN1HWJArMSZuWV3gmMqn4xtpdJFJ6XDfJAFNcqS61/dgLqK6gH/Fp42FmmSBN3y/E+xmz1xfz5hlSKsetNDDf1AxFC/wawnvh+ANFent7Q2323tdPOIuwYQKwp6cnu+hrWZb0eD1sKiXcivUznbTmCq81TCq+saYdhSHsJjguzTbgvw1KaRCWVM3vbBB0Pnu19lK8djKOwO8v0Nb/vnfGYRhGoII1E9ECv0bo7e0VIyR52Zl1dbLZNHM0ItdO6l38SoN0RaOyPpnMCTtf6CSZEimi1VVKuBUT6AGCoGYXzqaxhl9srOPS8AP+26AkfWH++paTBC1IS3c18H7GfOpHiwhu7/vlBBgKuQvJM12zd9ECv0bwB1N5T8TNppmz+OqGtS8l3xPHTV/gDzt3tbdCHkCFBEZFBXI5ZoFqM51mI2WOtVL/aZCyElQvOR6PS2NjY46GnyZXo/fb5L2Lv8OEe/SEbe6CcTHnhZluu3fRAr9GcINSFjDmNzwScoJnyE0g5S9NGOQS517QQT78WeFeQGBUVCCXYBaYDRfftKDEm0ih88O/76xYLKtsFBPgrkeOG0FbzEYfdJ24M+NRxqLIvWmW3S0Wi9XeDLPCaIFfI7xSqexCVpCHQtjJvN13cwjTZB5++OGcCy9vWl3EgyPmCZyZsEAOMQtMpYZfsyakKjPejKOF1ob8N/Mz6+pkRyyWd64HmWb853GQOSjMjOM1gXrfO4Tt4eZ+/yHs2fJsMO9ogV8jdEWjgQtZpUxZ3QsiKILR1WTc0HL3pA7U8D34F5BNX678Sl8QUy2Aa9aEVGXGm3G0HA2/27JCA7cy5NvtvTPVUlOJjBCepC3Is23E0/8CnAj06WLKKwMt8KuIV8gV01xK2YqljPVeeAtN077wQk5ov1bmam4zRSPWJqRgxptxtNDakF/7H41GQ8/hNMiAaQZq/q4wDpsFB80UynX3TGP78ufclDzHPd1nhlrgTxG9vb2STCbFMAw5xTBkh5Noqp18W3zYiVro5HXzhni9c7w2yrNisZwAmUHDsKfrBWyyfoE/k4Si1vCDGW/G0UL5nwpp+IHnejSak1LbG6nrCvxSr4tShL5//yjkBI0Jdory3iqYHiuNFviThF8TaGxszApOby4RdzrZXeTkLPS+Gz3oBpI0NDTkCGqllAw2NuZPowtobP7C06bHtXMmMN01tclivL9LoQyvQTZ8b7bVYw0NgULaNct4lZdN5Nvly/HaKeUmMYpds8Ffqcv9XaazEqQF/iTh1wS8J0lQUrNyNBF/u37sqbJ7cQa5d4pPY/F+NuzC1kJRUzYBHlj+a8GfY3+XR5v3n+dusjNX4PtNn+MR9sUUqMPYRYXcKm3eNMvTPSpXC/xJIsgG7m7pcZyYYY+urd7VwHt7e7Pf401SFVQgxf1sqSfuTLoBzKRjqQkcz6t0XZ0MmKYMYBfmuayxMS9VSNSX4yew2I7vPHXNlV7Pm0JFUSay+atnebfGxsZpfd5ogT9J+L1cvMK33MCRQtqI16XM1UCCcpUU+2wpU9Ppbr/0MpOOpSbwaPZBDgORSEQua2yUbifS1tWaI06u/GJKkNchwQ3OKnedq5Trzl0cDhP4hmFU+5eeEIUEvrL31x5NTU2yffv2ag+jIH19fSxevJj+/n4AtgBJwMA+cwBUkT4EGAQeB5qBOQFtRoCtwDrntWEYPJzJhLYP+uzFkQjNzc20t7cXbG9ZFgMDA9nX8Xg8e3zTjZl0LDWBZYHn9+wH5vuatANrsM/LEeAI9jXwpPPeKnKvCXFeZ5wtErAP33sDQDxgXym41+VjwJXAgZB2vb291NfXj+Mbqo9SqktEmoL2GVM9mJlEfX09mUwGgKXYJ7r7g/pP6jCUs7ViC+bRgPZzgIT3M0qRIEDYRyL2Ren77EqgubmZtrY2wL5RtbS0YFkWLS0t9PX1ZdsnEgkikYjTXYREIsGE6euDlhZ7bC0t9uspYFKOZTaTSNjnGLYw7/btjkQirGDsvJwDWM7WhC38077PKM/jy06/ECzsM9iC+jynn1JUVX8b93pbA7yAraQtCPhca2trCb1PQ8JU/2pv08GkIyJZL5dC+bmLTS/dkPLD5JZr8+YbcaegkUhEkslkTpHxDNjpicPy5fh88QuZOibF7l1mwq9KoW34lcF1Nz7FMGQTyIDjcrwoGpVkMimNjY1iGIaYTvnMsJKch0G2FbhOMs5+Nx2D38st6NqYqH0/jR2H4M8TZBjGtD1f0Db8yuIVJEopoYwTL8wm6Rfu3vUA97Xr6paOxeyKRJ4C0jm+0960BpY1tphbrZw20yn9sCaP0EyZnv3eYL/Npin95CY0c8/rYnlyvNk0/emTC61XFbveCmXVzIBsdnL4hx3jdEIL/AqTSqWyidDAXhStpDeBtx6tdwuLDCxILWStrKCGr7X2qSfIG82rJIQpEAd6enKqt71SqZKjzUtdrK3EAq73hjSlitAkoQX+BPELmeOPPz57UvjDwP2+xuPR/MO8CIICXrzji8ViYlmWRJ3grLACFVMuNCuYflh73lSQMrJklqrhF/tPui0rT0svNxBxPDeMUvpyM2y6N6izYrFpqVBogT9BCgVYBU1RC00fS928hRvc7w3T8AtV0ZpWud4dCt2QpnsUZE1R4szLteGbpimGYUgymcz5TwoqHD4O9PTkBWGFCewgc8x4FahS2nv7dzV+b7DjdEEL/AkSNKV1bezl5vAoZXMXkpLJpCSTyazgO9DTEyi8wwLApqswLCcro9bwJ0CF11bK+m8MI/C8L5QQLYOdhiEdjYoEJF8r5eYR9l7Y920CuaShQUSmjzlRC/xx4P1zvXniFzDmaVCOjbCY9uLdtysWs4V7iRTU8KchhbT46XLR1RqBv1uFvaf8/5thGLIoGg12NAhIteA6LxSzy++IxUQefjgb4FiOBl+q0uXX9EWmj7KhBf448AvRpYy5XpartfunpP3OTcOt1OPdf2gcJ1M5U+rpwHS5sKYTgb9phc19QYpHWDHzQspQsTbD2OmV084soZSbRDnXq3/rdwT+dDEnaoE/DvzVn0rxsy/1pMtg2/6DFmL7a/xkmgq0Fl95pkJYef8314utkFeO1x25kIJUyrU2Xi+5Ygpcdn8qJeunSVK1QgJfR9r6cKNQBwcHc963KB7KHbZffPsUsNp5/jhj0YUjzuvZHhVaX19Pe3s7/f39tLe3T9sQ91piKqKOvf9bU5Md2d/N2Pntx5tSQZz3vHcltw2efV4yzuMI0DmBcRe6rt3IXNmyhTtHRqirqwOgrq6OO+64YwLfWh20wPfR2trK1q1bs68XANuc5/4TLuw9P0EnlAl0GAYfq6vjt4bBkGGwKxbjumg0Jw1CIQqlSNBovLS1tdHc3Ew8Hi/5/KoEbsqQIcOAZBJisey+EezUBsux8/KI87gcO19OIWHv3iz6nf6v9PTh/Uyh69OviBVCpdNkduzI5mI6cuQIN9xwQ4mfriHCVP9qb9Uw6fT29uaFWJfiiVOuicd9f8SZKo4XbevW1CqhJqTeXjmWTMqgaWYrwbltvNdeWHU477XT4btWlzom0fGssxW7dt31tcBjqjHQJp3SaG1t5aRMhk3Y2sJhIEWwFlCKZu9v65+mRoChLVuyGvquXbuyGvuaNWtYs2ZNQe29u7ub0dFRAEZHR+nu9qez0miqQyET0lNPPUU6nc5eD4ZhkEqleP755+nt7SWVSnG1YbAV+zpMk5tkDSCSSvGl1avx8iS26dXb3k8xrd9F+dop7Ayd/cAmYKFp5hzTtJlth90JStmAE4H/Bp52Hl8R0CaBPet6EngC+JtS+p5KDd9dbIKxHPOFNPRKafv+iFrTNPO8HCigvWsNX1OrhC68p1J5+XWCNGX384aTsM2bJ19MU8SJSzkrFssWVD9Ebg6eoM1fHL3YdR7kqz+M7RqaTCazbqfe2tXVvhaZLC8d4Fbgk87zTwJfDGizGDjbeb4QOyvpCcX6niqB76/rWmquj3JNOP6iKO4UMShnTtBW6KLQ3iyaaYMv2OswhZOUxePxnGI/OddYMplTl7aYd4/rHVcJRW7UGXtQgriw63WqKCTwJ2rS2QD8wHn+A+y1kxxEZI+IPO08fx675sDJE/zeitHa2ppTFKMbyjLXeAlaZHIl9j7fvkHsO2FYAQYvYV4V2ptFM+1IJBBPTv0/WtbYAnJA3YREIsGfI5Fs8Z8cU8327czdvTtbNMVv9oH8a3kNFDXrePeHtTMYy/Xvzf+foMa97MLuBKVswCHf678UaX8u8BRghOx/H7Ad2P7qV796Eu+BY/hrby6gPJ/eUtoNkF/UfKQErd6bVkFr75oZQaFgryKJ/kb915ZbA8L5zERSLQS1CTL/FJIBw9gpUap9vTKREodKqQeBVwbs+ifgByJygqftX0TkFSH9nAI8ArxTRB4rdiOazBKHfX19tLa20t3dzZEjR0inx+rwLAD2Y7tNjqeEmh8BOrCr9HjLt41SuDyhYRg549JoZjy+EorE4+AtSblmDXTaHveC7br5942NfHvOHObu2gVHjyLpdHbB1XXdhHz/c1fqhTlkBC3aBpFhzIW0G/jfySTf2rixqrPtCZU4FJFLRGRZwLYR6HMEuSvQAy0USikL+CXw6VKE/WThrqSfeuqpdHR0MDAwkCdU26icsHdpxfbld0++DGO+/S4xj38ywGqfB4JGM+PxlFAkErFfe9m4ESwrK5CPB967YweXzJ0Lg4Owfz9bDIMBbG+aAeyArE5yg7tcCgl7d7/yvB+EAnYDZ2PXnL6/q6umyyNGijcpyM+BdwJfcB43+hsopeYCPwN+KCJTE+0RghtUVUhzXsn4iyN7tQJXu+jEvgteiX0zSWBrAt5TIhaLsXXrVm644Qa6u7tJJBJTFhgDMDIywnPPPcfRo0en7Ds1s4d58+Zx2mmnMWdOoTkt0NYGra3Q3W0Le/81UF8PItnrcw6wAsbckevr+dTatWzdujXrrgz2rH0v4FWpvLMAyLXb+69/5dkftK8J+9pexzRwjw6z9ZSyAX8FPITtlvkQcKLzfhPwbef53zJW89jdEsX6ngwvnbA0wqZpSjweF8uy8rxpytky2EnR3Pq0bpWfoO/0btUO4Ni3b58cPHhQMplMVcehmXlkMhk5ePCg7Nu3rzIdplLZ9bBhkHZyvXz8nmsQHDwZdI33E+7F47pQh63vufUrqu2SKVLYhj8hgT+Z22QI/KBsfoBEnWLMSycg7L0nhduvWyzC6yufTCZz3EBN06z6CbJ7924t7DWTRiaTkd27d1emM0+k7mbDkPW+Yix+DMMIdLXOYOfV97tUtgQIdXcBF4Kz5rqfNWpgwVaksMCfVZG2bj4Rw8g97KGhITo7O3m0zP6800Cwp3eu1TESibB27Vo2btyYk8Nk48aN7Nmzh1QqRTwe57zzzptS800YSlVy1UKjGWN0dJTe3t5xRaHmRbACcx97jOjoKGvTaTY+9ljBBdLVq1cHJnBTgAwN0cVYPp6rDYMH6+pybPduW9fY+SRwArYXS4fvszt37gTg7LPPrt1o27A7QbW3yQy8SiaTgaaVUvJz++/6g0rl5PfYEYtNO1fKimlfGk0ATz31lPzqV78al8ljotHkvb29sj6ZlM2GIaO+6zlNfu3osPz7QTWmvVssFquZyHe0hj9GX18f27bl+sgswM7aB7kaO+Qv0rj/8ABwXl0d0RdeQKVSEI8TSaVYuXevDoQaB729vVx99dWcddZZLFmyhMsvv5w9e/bwyCOP8KY3valq43rmmWe48847s6+3b9/Ohz70obL7efzxx1FK8cADD1RyeGXx7//+7/zwhz8E4IILLiDI7fnnP/85X/jCFwC4+eab+fKXvwzAZz7zGR588EEAvvrVr3LkyJGSv9fbttxFzYnmi6qvr2fjY4+xNp3mLckkXncNg7EZuYvHCTRnobYOW0b0A4cYy6mzAHs2v3LlymmR22pWCHzvtHDx4sVkMpmc/W1AEvKmcl4E23e+A3s691eRCL+PRIiddRbzd+4kLkILUIOTuJpHRHjzm9/MBRdcwB/+8Ad2797Nv/7rv5Y1JZ6smAW/wG9qauLrX/962f3cddddnH/++dx1112VHF5ZvP/97+cd73hHwTbr16/nk5/8ZN77t9xyC5dccglQvsB3c8hD+VGolczj//Du3Wwht/5Ej2lm95umyQcbG8lEozmRthGgEVtGxLGja+NAM7bscNNN+8e6ZMmS2kuoFqb6V3urpEknbLHWN+etJgAAFVVJREFU3QZKWIwdYSzvjVIqW9HHu9XCCv14KNekU+kcPg899FDo7/bwww/LunXr5KqrrpLXvva1cs0112QXmE8//XT553/+Z1m7dq3cddddcuedd8qyZctk6dKl8vGPfzzbRzQalY9//OPS2NgoF198sXR2dsq6devkzDPPlI0bN4qIyB//+Ec5//zzZeXKlbJy5Up59NFHRUSyi+wrVqyQr3zlK/Lwww/LFVdcISIiN910k1x33XXZvr72ta8FHkMmk5EzzzxT9u7dK6eccoq8/PLL2X1f/OIXZdmyZbJ8+XL5xCc+ISIiTz/9tFx88cWyfPlyWblypezdu1dERG699VZpamqShoYG+cxnPiMiIoODg3L55ZfL8uXLZenSpXL33XeLiMgnPvEJOeecc6ShoUH+8R//MTveL33pSyIism7dOvnwhz8szc3NsnTpUuns7BQRke9973vygQ98IK/9O9/5Tmlra5Ovfe1rMmfOHFm2bJlccMEF8u1vf1s+8pGPZI/nW9/6ltx44405xz88PCy/+c1vxnW+VPJcS6VSstA0ZRO2V023ZcmBnp68/rstK7Qso39Lx2KhY/U7bEyVbGC2e+mEuWO6W1gItbsSf9hZnXe9bsLWAKD6LpbjoVyBX2lb5de+9rUcoeHl4YcfFsuy5Nlnn5V0Oi1r1qyRjo4OEbEF/he/+EUREdm/f7+86lWvkgMHDsjIyIhceOGF8rOf/UxERAC5//77RUTkyiuvlNe//vUyPDws3d3dsmLFChERGRoaygriPXv2iHv+eQW8//VNN90kzc3NcvToUTl48KCceOKJMjw8nHcMHR0dctFFF4mIyNve9jb56U9/KiIi999/vzQ3N8vQ0JCIiLz00ksiInLuuefKvffeKyIiL7/8sgwNDckDDzwg733veyWTyUg6nZYrrrhCNm3aJPfcc49cf/312e86dOiQvPTSS7J48eLsjfEvf/lLdrxege9+btOmTbJ06VIRKS7w3d/94MGDImLfcBYtWpQ97ubmZnniiSfyfoNaWCcqdPPw7gvz6vHn5A9K/+Dtt1o1cAsJ/Flh0gmaBhqGgWVZLKBwZO0TwHzs1XnDMJg7dy67d+8ObFvTSZMqyFTbKs8991xOO+00DMMgkUjwzDPPZPf9zd/8DQDbtm3jggsu4OSTTyYSifD2t7+d9vZ2AObOncsb3/hGABoaGli3bh1z5syhoaEh29fIyAjvfe97aWhooLW1NfQ/9nPFFVdw3HHHcdJJJ7FgwYLAaftdd93F1VdfDcDVV1+dNes8+OCDXHfddVmTx4knnsjAwAD79+/nzW9+M2AHLdXV1fHrX/+aX//616xcuZLGxkZ+97vf8fTTT9PQ0MCDDz7IJz7xCTo6Opg/fz6WZTFv3jyuv/567r333hyTipe3ve1tALS0tNDf38+hQ4dKOmYv0WiUiy66iF/84hf87ne/Y2RkhIaGhrL7mQoKJRt0gzIHBgZyvHoy2Kbcx4BthkG6rg5lWXblruZmaGvL+ezWrVuzkbZTUVayXGaFwA9ye8xkMpxzzjnca4T/BAo40/PaFW7ePxJs218sFpvS0nHVpNIn8tKlS+nq6grdf9xxx2Wfm6aZE0UZjUYBe6Yaxpw5c7Jup4ZhZPszDCPb12233UZ9fT07d+5k+/btDA8PlzT2QmMDe23hpz/9KbfccgtnnHEGH/zgB/nVr37FwMAAIpLnDht2HCLCpz71Kbq7u+nu7mbv3r285z3vYfHixXR1ddHQ0MCnPvUpbrnlFiKRCL/97W+56qqruO+++7I3Oz/+7x6va+7111/P97//fb73ve9x3XXXjauPauNVYtyyjP3AZuBU7FxYyUyG1xoGrFgBnt8qTAGqVlnJQswKgV9fX5/new/Q2dlJQyYTqt274cEurnDz/pGpVIr9+/czMDCQozVMmwo446DSJ/JFF13EsWPH+I//+I/se9u2bWPTpk0l95FMJtm0aRMvvvgi6XSau+66i3Xr1pX8+cOHD3PKKadgGAY/+tGPsovA8XicAW9CrzJ58MEHWbFiBc8++yzPPPMMf/rTn7KC+A1veAPf/e53swugf/7zn7Esi9NOO4377rsPgGPHjnHkyBEuvfRSvvvd7zI4OAjA/v37OXDgAM8//zx1dXX87d/+LR/96EfZsWMHg4ODHD58mMsvv5yvfvWroTOwH//4xwBs3ryZ+fPnM3/+/JKOyf+bJJNJnn32We68887srKFahF13xa5HrxJzADtNwnxs4d+GXf1uE/CjwUHYutVO8rZ1K7S2hipAtZi+fFYIfAg264BtqgnTDeekUpzT05MNknKFWyl/ZNg0byZQ6RNZKcXPfvYz/vu//5uzzjqLpUuXcvPNN7Nw4cKS+zjllFP4/Oc/z4UXXsiKFStobGxkw4YNJX/+hhtu4Ac/+AFr1qxhz5492ZnD8uXLiUQirFixgttuu63sY7vrrruy5hmXq666ijvvvJM3vvGNrF+/nqamJhKJRNYF8kc/+hFf//rXWb58Oeeddx69vb284Q1v4JprrqG5uZmGhgbe+ta3MjAwQE9PD+eeey6JRILPfe5zfPrTn2ZgYIA3velNLF++nHXr1oWO+xWveAXnnXce73//+/nOd75T8jG9733v47LLLuPCCy/MvvfXf/3XrF27lle8IjBZ7pQRdt3531+8eHGO8HeVGNPjtROJRLgH2xvHch5XA7izuNFR6O6uSU0+lDDjfrW3SgdehS20hlbAMYwJeQhUa8FmPNTCgppmenPFFVfIgw8+GLp/qs4x/3UXjUazOXWCNq/TQW9vrySTSTFNM+ugMVJXl7t4axjZ/PsjFM9/7w38GjRNOZZM5tYAmASYTYu2YVO3sEW4pYQs2K5ePSEtvRYXbDSaSnPo0CEWL17M8ccfz8UXX1zt4eRdd6ZpsnXr1tD2Xpt7a2srXV1dpNPprINGZNWqnJTNavVqaG5myDTZCrwlkykoG1pbW/loZyfnZjJE02mMzk47I2i1CLsTVHsbr4Yf5jIY5ovvL5A8CtlKPBPR0qdTvVmt4Wsmm6k6x/zXXSwWy7vmLcvKxtF4ZUTg9e6p0HUsmZT1ThU6wzBKkg2Bbp6TPNtnNvnhhwlp74ngDZpyCyS76YwXRaPZvmolN8ZkowW+ZrKp1jkWdA2HKWPFrvcwpbGQbEilUtLuUSpHXIVyEplVAj+VSuUIdMuy8rTrnp6ebIpi114X9McFnRjTSXMvFS3wNZNNtc6xcq7XYm39yqRbR6OSNvxKyJdZJfB7e3tz8s0X08zL/YFnotavBb5mspkJ59hUXPuV+I5CAn+iJQ5rjvr6evtO5lAsEtR1MSyV6ZART6PRVJ42J6p2MsuQTrZ8mXFeOjC5HjLa+2Zy6Ovr45prrmHRokWsWrWK5uZmfvazn03qd958882ceuqpJBKJ7Dae9AKTgTcdsaY2mIpAqsmWLzNS4E9mIMS0CrKYJogIV155JS0tLezbt4+uri7uvvtunnvuuUn/7htvvDGbrqC7u5sTTjhhQv1VKk2zNx2xZvYw2fJlRgr8ybwT12K49JTT1wctLWBZ9uME00b85je/Ye7cubz//e/Pvnf66afzwQ9+ELCF6Mc+9jFWr17N8uXL+eY3vwnAI488wgUXXMBb3/pWXve61/H2t789a87r6upi3bp1rFq1iksvvZQXXnih5PF85Stf4d3vfjcAPT09LFu2jCNHjnDzzTdz7bXXctFFF3H22WdnU0E88sgjXHjhhVxzzTU0NDSEjveFF16gpaWFRCLBsmXL6OjoIJ1O8653vYtly5bR0NCQjYp917vexT333APAQw89xMqVK2loaODd7343x44dA+CMM87gpptuorGxkYaGBn73u9+N+z/Q1AaTLl/CjPvV3iazxKEml7IX1FKpbLShmyJ2IhRKjywi8s1vflM++9nPiojI0aNHZdWqVbJv377Q1MnDw8PS3NwsBw4cEBGRu+++W6677rq8fm+66SZZuHChrFixQlasWCEXXHCBiIik02lJpVJy7733yqpVq2Tz5s3Z9suXL5cjR47IwYMH5bTTTpP9+/fLww8/LHV1dbJv376C4/3yl78s//Iv/yIiIqOjo9Lf3y/bt2+XSy65JDsmN5Wxm4745ZdfltNOO01+//vfi4jItddeK7fddpuI2GmKv/71r4uIyO233y7vec97xvPzTwkzYdF2usBsWrTVTAHd3Xn5RCrJBz7wATZv3szcuXPZtm0bv/71r3niiSeyGu/hw4d5+umnmTt3bjZ1MpBNnXzCCSewa9cuXv/61wP2DOGUU04J/K4bb7yRj370oznvGYbB97//fZYvX87f/d3fsXbt2uy+DRs2cPzxx3P88cdz4YUX8tvf/pYTTjiBc889lzPPtHOrho139erVvPvd72ZkZIQrr7ySRCLBokWL2LdvHx/84Ae54ooreMMb3pAzlt///veceeaZLF68GIB3vvOd3H777XzkIx8B4C1veQsAq1at4t577x3/j66ZFWiBrymfRMLOFDg6aoedVyA98k9/+tPs69tvv50XX3yRpqYmwJ6F/tu//RuXXnppzuceeeSRwPTEIsLSpUsLhtQX4+mnnyYWi/H888/nvB+WUthNtlZovADt7e388pe/5Nprr+VjH/sY73jHO9i5cycPPPAAt99+Oz/5yU/47ne/m9NXIdzjD0rNrNH4mZE2/ELM5LTFU0Zbm138IR7PFoGYCBdddBFHjx7lG9/4RvY9b83USy+9lG984xuMjNhlKfbs2cPQ0FBof6997Ws5ePBgVuCPjIzw5JNPljyew4cP8+EPf5j29nZeeumlrKYOsHHjRo4ePcpLL73EI488wurVq/M+HzbeP/3pTyxYsID3vve9vOc972HHjh28+OKLZDIZrrrqKj772c+yY8eOnL5e97rX8cwzz7B3717AzqRZTtpnjcbLrNPw3YRoo6Oj2aRH5fjha4D6eqjgb6aU4r777uPGG2/k1ltv5eSTTyYajfLFL34RsAtsPPPMMzQ2NiIinHzyydl88UHMnTuXe+65hw996EMcPnyY0dFRPvKRj7B06dK8trfddhv/+Z//mX193333ccstt3DDDTewePFivvOd73DhhRfS0tIC2NW3rrjiCv7nf/6H//W//hcLFy5kz549OX2GjfeRRx7hS1/6EnPmzCEWi/HDH/6Q/fv3c91115HJZAD4/Oc/n9PXvHnz+N73vkdrayujo6OsXr06Z3FboykHVWzKWC2amppk+/btFe/Xsqyc4g3xeJz+/v6Kf8904qmnnuKcc86p9jBqnptvvplYLJZn89cUR59jU4dSqktEmoL2zTqTjg6c0mg0s5VZZ9KZivBozczk5ptvrvYQNJoJMesEfrm5c2YLIvkFtTWaSlCrZuPZyKwz6WjymTdvHi+99JK+MDUVR0R46aWXmDdvXrWHomEWaviafE477TSee+45Dh48WO2haGYg8+bNywbHaaqLFvga5syZk40S1Wg0Mxdt0tFoNJpZghb4Go1GM0vQAl+j0WhmCTUbaauUOgj8KWDXScCLUzycyWSmHQ/MvGOaaccDM++YZtrxwPiP6XQROTloR80K/DCUUtvDwoanIzPteGDmHdNMOx6Yecc0044HJueYtElHo9FoZgla4Gs0Gs0sYToK/G9VewAVZqYdD8y8Y5ppxwMz75hm2vHAJBzTtLPhazQajWZ8TEcNX6PRaDTjQAt8jUajmSXUvMBXSp2olPpvpdTTzuMrQtq9Win1a6XUU0qp3UqpM6Z2pKVR6vE4bS2l1H6l1P+ZyjGWSynHpJRKKKW2KqWeVEo9oZT6m2qMtRBKqTcqpX6vlNqrlPpkwP7jlFI/dvZ31uo55lLC8fyDc6088f+3dzYhchRhGH5esywiRo0J+VGjMZA9hBwMLkEPIf4kIB6ihyALBjYgHtyzQiCe9KSiIigoKBiFYIhoXPwBTXRRhMEVVg0K5mcFs2RJDppAEDXi66FrpVlm07XTs929TD3QTHX3N1PvOzX9TXVVT4+ko5JuqUPnfCjylIvbJcmSGn2pZowfSQ+FdvpR0oFSFdpu9AI8C+wN5b3AM3PEjQE7Qvlq4Kq6tZfxE/a/BBwAXq5bd1lPwACwIZRvAKaB6+rWntO3BDgFrAf6ge+BjbNiRoBXQ3kIOFi37pJ+7p45ToDHmuwn1lOIWwp8CbSAwbp1l2yjDcAEsCysryxTZ+N7+MADwP5Q3g88ODtA0kagz/ZnALYv2v6jOonzotAPgKTbgVXApxXpKkOhJ9vHbZ8I5TPAOaDtrwFrYgtw0vak7b+Bd8h85cn7fBe4V83915hCP7a/yB0nLaDp9zCOaSOAp8k6IX9WKa4DYvw8Crxi+3cA2+fKVLgYEv4q29MA4XFlm5gB4Lyk9yRNSHpO0pJKVcZT6EfSFcDzwBMVa+uUmDb6H0lbyHo0pyrQFsuNwOnc+lTY1jbG9j/ABWB5JermT4yfPI8AnyyoovIUepK0GVhr+8MqhXVITBsNAAOSvpbUknRfmQobcT98SUeA1W127Yt8iT5gK7AZ+BU4COwB3uiGvvnSBT8jwMe2TzelA9kFTzOvswZ4Gxi2/W83tHWJdm/07GuWY2KaQrRWSbuBQWDbgioqz2U9hY7Si2TH/mIgpo36yIZ17iI7A/tK0ibb5zupsBEJ3/b2ufZJOitpje3pkCzandJMARO2J8NzDgN3UFPC74KfO4GtkkbI5iP6JV20Peck1ULTBU9Iugb4CHjSdmuBpHbKFLA2t34TcGaOmClJfcC1wG/VyJs3MX6QtJ3sS3ub7b8q0tYpRZ6WApuAsdBRWg2MStpp+9vKVMYT+5lr2b4E/CLpZ7IvgPFOKlwMQzqjwHAoDwMftIkZB5ZJmhkTvgf4qQJtnVDox/bDtm+2vQ54HHirzmQfQaEnSf3A+2ReDlWoLZZxYIOkW4PWITJfefI+dwGfO8ykNZBCP2H44zVgZ9mx4Yq4rCfbF2yvsL0uHDstMm9NTPYQ95k7TDa5jqQVZEM8kx3XWPdMdcRM9nLgKHAiPF4ftg8Cr+fidgA/AMeAN4H+urWX8ZOL30Pzr9Ip9ATsBi4B3+WW2+rWPsvH/cBxsrmFfWHbU2RJA+BK4BBwEvgGWF+35pJ+jgBnc+0xWrfmsp5mxY7R4Kt0IttIwAtkHdhjwFCZ+tKtFRKJRKJHWAxDOolEIpHoAinhJxKJRI+QEn4ikUj0CCnhJxKJRI+QEn4ikUj0CCnhJxKJRI+QEn4ikUj0CP8BTbm6H4kvYKUAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from sklearn.decomposition import PCA\n",
    "\n",
    "pca=PCA(n_components=2)\n",
    "Xy_pca=pca.fit_transform(np.concatenate((X_new, y_new[0]), axis=0))\n",
    "X_pca=Xy_pca[0: 1047,]\n",
    "y_pca=Xy_pca[1047:,]\n",
    "\n",
    "plt.scatter(X_pca[:,0], X_pca[:,1], c=\"k\", s=15, label=\"Chromatin Accessibility\")\n",
    "plt.scatter(y_pca[:,0], y_pca[:,1], c=\"r\", s=15, label=\"Gene Expression\")\n",
    "plt.legend()\n",
    "plt.title(\"Colored based on domains\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
