{
 "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": 1,
   "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": 2,
   "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": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[  6.6883364 ,  -2.3696006 ,   2.14278082, ...,  -0.38985914,\n",
       "          0.03180685,   0.16824296],\n",
       "       [ -1.64704263,   3.87629104,  -2.57201982, ...,  -0.56939318,\n",
       "          0.77513025,   0.40657076],\n",
       "       [ -3.22729615,   4.55422489, -10.10911411, ...,  -0.50277229,\n",
       "          0.11965411,   0.70274427],\n",
       "       ...,\n",
       "       [ -2.60360565,   3.75489872,  -6.05216412, ...,   0.24619445,\n",
       "         -1.72947077,  -3.24436   ],\n",
       "       [ -0.94623495,   4.54416359,   2.29832621, ...,   2.12374688,\n",
       "         -1.05837995,   0.42656378],\n",
       "       [ -2.49249336,   4.43299686,   1.91649138, ...,   1.89995418,\n",
       "         -2.62129623,   4.05023675]])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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.723608e-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": "markdown",
   "metadata": {},
   "source": [
    "##### Evaluate results:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average FOSCTTM score for this alignment with X onto Y is:  0.14902407132460765\n"
     ]
    }
   ],
   "source": [
    "fracs=evals.calc_domainAveraged_FOSCTTM(X_new, y_new)\n",
    "print(\"Average FOSCTTM score for this alignment with X onto Y is: \", np.mean(fracs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYIAAAEGCAYAAABo25JHAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Il7ecAAAACXBIWXMAAAsTAAALEwEAmpwYAAA1tUlEQVR4nO3deXhU5fXA8e8hoKwiqyBr2EkIhBAQRMq+uKHIIliVqi1U1IqtCLiAWq2iWLfqT6FsrQoIolBFRVAUBRGCyBJAtgBBQYiA7BByfn+8k2GyMATIzSSZ83meeWbuMveeyyVz7n3vu4iqYowxJnwVCXUAxhhjQssSgTHGhDlLBMYYE+YsERhjTJizRGCMMWGuaKgDOFcVK1bU2rVrhzoMY4wpUBISEvaqaqXslhW4RFC7dm2WL18e6jCMMaZAEZFtZ1pmRUPGGBPmLBEYY0yYs0RgjDFhrsA9I8jOyZMnSU5O5tixY6EOxRiTjeLFi1O9enWKFSsW6lBMNgpFIkhOTqZMmTLUrl0bEQl1OMaYAKpKSkoKycnJREZGhjock41CUTR07NgxKlSoYEnAmHxIRKhQoYLdsedjhSIRAJYEjMnH7O8zfys0icAYY8z5sUSQS55++mmio6Np2rQpsbGxLF26FHAPskeMGEH9+vWJi4ujTZs2fPzxxwAcOHCA22+/nXr16lG3bl1uv/12Dhw4wOrVq4mNjSU2Npby5csTGRlJbGwsXbp0yXE8tWvXZu/evQBceeWVuX/AF2jlypXMnTs322ULFy6kbNmy/n+DwOMeN24cjRo1olGjRrRq1Yqvv/7av+zDDz+kefPmNGvWjKioKN58803/sv/85z80adKEmJgYmjdvztixY7nnnnuIjY0lKiqKEiVK+PcnIsTGxlKvXr0McSxevJgOHTpQs2ZNAsfxuPHGGyldurQH/0rG+OzfDwsXwm+/ebN9VS1QrxYtWmhmiYmJWeblpcWLF2vr1q312LFjqqq6Z88e3blzp6qqDh8+XG+//Xb/sl27dun06dNVVbV37946evRo/3ZGjRqlffr0ybDtgQMH6owZM845plq1aumePXvO53DyxKRJk/See+7JdtkXX3yh1157bZb5//vf/zQuLs5/XAkJCVqjRg39+eef9cSJE1q1alXdsWOHqqoeO3ZM169fr6qqc+fO1ebNm/vPybFjx3TcuHH+7W7dulWjo6NzFEf79u01JiZGFy1apKqq+/bt01atWmmpUqXO9Z8g7IT677RA+/RTVVBduPC8NwEs1zP8rtodQS74+eefqVixIhdffDEAFStW5PLLL+fIkSOMHz+eV1991b/ssssuo1+/fmzatImEhAQee+wx/3ZGjRrF8uXL2bx5c473feONN9KiRQuio6MZN25ctuukX62mpaUxZMgQGjVqRNeuXbnmmmuYOXMm4O4gRo8eTVxcHDExMaxfvx6Axx9/nIEDB9KuXTtq1arFrFmzeOihh4iJiaFHjx6cPHkSgISEBNq3b0+LFi3o3r07P//8MwAdOnRg+PDhtGrVigYNGrBo0SJOnDjBqFGjmD59OrGxsUyfPj1HxzpmzBief/55KlasCEBcXBwDBw7ktdde4+DBg6SmplKhQgUALr74Yho2bAjAM888w9ixY7n88sv9y/70pz/l+N84s/79+zNt2jQAZs2axU033XTe2zImR3budO81a3qyeUsEuaBbt27s2LGDBg0aMGTIEL788ksANm3aRM2aNbnkkkuyfCcxMZHY2FgiIiL88yIiIoiNjWXt2rU53vfEiRNJSEhg+fLlvPLKK6SkpJxx3VmzZpGUlERiYiL//e9/WbJkSYblFStWZMWKFdx9992MHTvWP3/z5s18/vnnzJkzh1tvvZWOHTuyevVqSpQowUcffcTJkye57777mDlzJgkJCdx555088sgj/u+npqby3Xff8dJLL/HEE09w0UUX8eSTT3LzzTezcuVKbr755iyxLlq0yF8k8/TTTwOwdu1aWrRokWG9+Ph41q5dS/ny5enZsye1atViwIABvP3226SlpQGwZs2aLN+7EJ07d+arr77i1KlTTJs2Ldv4jclVvgsufBeUua1QtCMItdKlS5OQkMCiRYv44osvuPnmm3n22WeJi4vzfN+vvPIK77//PgA7duxg48aN/qvizL7++mv69u1LkSJFqFKlCh07dsywPP3KtkWLFsyaNcs//+qrr6ZYsWLExMRw6tQpevToAUBMTAxJSUls2LCBNWvW0LVrVwBOnTpF1apVs91uUlJSjo6rXbt2fPjhhzlaN92///1vVq9ezfz58xk7diyfffYZkydPPqdt5ERERARXXXUV06ZN4+jRo1hvuMZzqanuPeDCMTdZIsglERERdOjQgQ4dOhATE8OUKVPo168f27dv57fffstyVxAVFcXKlStJS0ujSBF3Y5aWlsbKlSuJiorK0T4XLlzI/PnzWbJkCSVLlqRDhw4XVFc7vfgqIiKC1PT/eAHzixQpQrFixfxVAYsUKUJqaiqqSnR0dJY7jLNt91xFRUWRkJBAp06d/PMSEhKIjo72T8fExBATE8Ntt91GZGQkkydPJjo6Osv3LlT//v3p1asXjz/+eK5t05gzOnXKvRf15ifbioZywYYNG9i4caN/euXKldSqVYuSJUty1113cf/993PixAkA9uzZw4wZM6hXrx7Nmzfnqaee8n/vqaeeIi4ujnr16uVovwcOHKBcuXKULFmS9evX8+233wZdv23btrz33nukpaWxe/duFi5ceO4Hm42GDRuyZ88efyI4efLkWYu3ypQpw8GDB89pPw899BDDhw/3F3+tXLmSyZMnM2TIEA4dOpTheNLPAcDIkSMZNmwYu3btAuDEiRP8+9//Pqd9Z9auXTtGjhzJgAEDLmg7xuTIddfBnDlQpownm7c7glxw6NAh7rvvPvbv30/RokWpV6+e/8HtU089xaOPPkpUVBTFixenVKlSPPnkkwBMmDCB++67j7p16wLQpk0bJkyYkOP99ujRgzfeeIPGjRvTsGFDWrduHXT93r17s2DBAqKioqhRowZxcXGULVv2PI/6tIsuuoiZM2fyl7/8hQMHDpCamsrQoUMzXKln1rFjR5599lliY2MZOXJkjsrZe/bsyc6dO7nyyisREcqUKcNbb71F1apVOXjwIM899xyDBw+mRIkSlCpVyl8sdM0117B79266dOmCqiIi3HnnnRd0zCLCgw8+eEHbMCbHIiPdyyOiAfWhC4L4+HjNPDDNunXraNy4cYgiKlgOHTpE6dKlSUlJoVWrVnzzzTdUqVIl1GGZMGB/pxdg40ZYvx6uuea8nxOISIKqxme3zO4Iwsx1113H/v37OXHiBI899pglAWMKghkz4JFH4NgxTx4YF85E0KFD1nn9+sGQIXDkiMuqmf3hD+61dy/06ZNxWS6VpecHufVcwBiTh9IrWdjDYmOMCVPptYaKePSTfaYmx/n1lR+7mAg3XnVfMXnyZK1Xr57Wq1dPJ0+enO067777rkZFRamI6LJly7Is37Ztm5YqVUqff/55/7yXXnpJo6OjNSoqSl988UX//JSUFO3SpYvWq1dPu3Tpor/++quqqr711lsaExOjTZo00TZt2ujKlSsz7CM1NVVjY2MzdD+xZcsWbdWqldatW1f79eunx48fV1XVoUOHarNmzbRZs2Zav359LVu2rP873bt317Jly2bpxuLOO+/Upk2bakxMjPbu3VsPHjyoqqovvPCCNm7cWGNiYrRTp06alJSU4XsHDhzQatWqZei64/jx4/qnP/1J69evrw0bNtSZM2eqqutmo1+/flq3bl1t1aqVbt261X/s6fE2a9ZMRUS///77oNuaNGmSVqxY0f+d8ePHZ3vu7O/0AjzyiGqRIhe0CYJ0MeHpjzbQA9gAbAJGZLO8JvAF8D2wCrjmbNsM10SQmpoa6hD8vEgEKSkpGhkZqSkpKfrrr79qZGSk/4c5UGJioq5fv17bt2+fbSLo3bu39unTx58IVq9erdHR0Xr48GE9efKkdu7cWTdu3KiqqsOGDdNnnnlGVVWfeeYZfeihh1RV9ZtvvvHve+7cudqqVasM+3jhhRd0wIABGX7A+/btq1OnTlVV1cGDB+vrr7+eJbZXXnlF77jjDv/0/Pnzdc6cOVkSwYEDB/yfH3jgAX+Mn3/+uR4+fFhVVV9//XXt169fhu/95S9/0QEDBmRIBKNGjdJHHnlEVVVPnTrlP2+vvfaaDh48WFVVp06dmmVbqqqrVq3SOnXqnHVbwfqNChQOf6eeGTFCtVixC9pEsETgWdGQiEQArwFXA1HAABHJ3FLqUeBdVW0O9Ade9yqevHT33XcTHx9PdHQ0o0ePBuCTTz6hb9++/nUWLlzIddddB8C8efNo06YNcXFx9O3bl0OHDgGu/5/hw4cTFxfHjBkzGD9+PC1btqRZs2b07t2bI0eOAK4LiNatWxMTE8Ojjz6aoSfM559/npYtW9K0aVN/LIHeeOMNhg0b5p+ePHky9957L3D2foySkpJo0qSJf3rs2LH+BlabN2+mR48etGjRgnbt2vn7LjqTTz/9lK5du1K+fHnKlStH165d+eSTT7Ksl15VNjsffPABkZGRGaqtrlu3jiuuuIKSJUtStGhR2rdv7281PXv2bAYOHAjAwIED+eCDDwDXW2u5cuUAaN26NcnJyf7tJScn89FHH/HHP/7RP09V+fzzz+nje7YUuK1AU6dOzdDuoHPnzpTJpl54euNDVeXo0aP+BnwdO3akZMmS2caVkJDA7t276datW4ZtTZw4kZEjRwKuAWB6P02Bx96nTx8WLFiQfnGWId7+/fufdVsmDwwaBPPne7Z5L58RtAI2qeoWVT0BTANuyLSOAulNbssCP3kYT555+umnWb58OatWreLLL79k1apVdOnShaVLl3L48GEApk+fTv/+/dm7dy9PPfUU8+fPZ8WKFcTHx/PPf/7Tv60KFSqwYsUK+vfvz0033cSyZcv44YcfaNy4sb/Nwf3338/999/P6tWrqV69uv+78+bNY+PGjXz33XesXLmShIQEvvrqqwyx9u7d299FRWBccG79GGU2aNAgXn31VRISEhg7dixDhgwBYM6cOYwaNSrL+jt37qRGjRr+6erVq7MzvaOtHDh06BBjxozJkuyaNGnCokWLSElJ4ciRI8ydO5cdO3YAsHv3bn9XGFWqVGH37t1ZtjthwgSuvvpq//TQoUN57rnn/K3BAVJSUrj00ksp6nuQl13s27ZtY+vWrTlu3XzHHXdQpUoV1q9fz3333Rc0rrS0NP72t79l6B8KYP/+/QA89thj/ouM9GMM/PcuWrQoZcuWzXJ+p0+f7k9cwbYF8N5779G0aVP69Onj//c1uSgyEn73O88272UiqAYE/o9I9s0L9Dhwq4gkA3OBrP/jAREZJCLLRWT5nj17vIg1V7377rvExcXRvHlz1q5dS2JiIkWLFqVHjx7873//IzU1lY8++ogbbriBb7/9lsTERNq2bUtsbCxTpkxh27Zt/m0FNrRas2YN7dq1IyYmhrffftvfenfJkiX+u41bbrnFv/68efOYN28ezZs3Jy4ujvXr12doAQ1QqVIl6tSpw7fffktKSgrr16+nbdu2gOvHqFmzZrRu3drfj1FOHDp0iMWLF9O3b19iY2MZPHiwvzfSnj17+hvU5abHH3+cBx54IMu4AI0bN2b48OF069aNHj16ZOnoL52IZBlF64svvmDChAmMGTMGcOMdVK5c+bw6sJs2bRp9+vTJdt/ZmTRpEj/99BONGzfO0jvrW2+9xfLly/13cq+//jrXXHNNhosAcJ39JScnc+WVV7JixQratGmT40ZwS5cupWTJkv47vmDbuv7660lKSmLVqlV07drVf6dhctHy5eDrKdgTZyozutAX0Af4d8D0bcC/Mq3zV+Bvvs9tgESgSLDt5vdnBFu2bNG6dev6y5gHDhyokyZNUlXVBQsWaK9evfTTTz/VXr16qarqnDlztH///tluK3NZfO3atf0PLidNmqQDBw5UVdXy5cvryZMnVdWVL6f3jf/Xv/5V33jjjbPGPGHCBH3ggQf0zTff1AceeEBVXV/8bdu29ZdJt2/fXr/44osMce3YsUMbN27s387f//53HT16tB44cECrVKly1v0Geuedd3TQoEH+6UGDBuk777xzxvUzPyO46qqrtFatWlqrVi0tW7aslitXTl999dUs3xs5cqS+9tprqqraoEED/emnn1RV9aefftIGDRr41/vhhx+0Tp06umHDBv+8ESNGaLVq1bRWrVp62WWXaYkSJfT3v/+9pqWlaYUKFfznYPHixdqtW7cM+42NjdVvvvkmSzxnGnsh3Zdffplh+WeffaaNGjXS3bt3++fdcsstWqNGDa1Vq5ZWqFBBy5Qpo8OHD9e0tDQtWbKknjp1SlVVt2/frlFRUaqq2q1bN128eLGqqp48eVIrVKigaWlp/m0OHTpUn376af90sG0FSk1N1UsuuSTbY8lPf6cFzj33qJYvf0GbIETjEewEagRMV/fNC3QX8C6Aqi4BigMFuuDxt99+o1SpUpQtW5bdu3f7RyMDaN++PStWrGD8+PH+4pfWrVvzzTffsGnTJgAOHz7Mjz/+mO22Dx48SNWqVTl58iRvv/22f37r1q157733APz95AN0796diRMn+p857Ny5k19++SXLdnv16sXs2bMzlAnnpB+jyy67jF9++YWUlBSOHz/u7y30kksuITIykhkzZgDuYuOHH34I+u/WvXt35s2bx759+9i3bx/z5s2je/fuQb8TaNGiRSQlJZGUlMTQoUN5+OGH/c860o95+/btzJo1y3/X1LNnT6ZMmQLAlClTuOGGG/zr3XTTTfz3v/+lQYMG/n0888wzJCcnk5SUxLRp0+jUqRNvvfUWIkLHjh39YzsEbgtg/fr17Nu3jzZt2pz1OFTV/39BVZkzZw6NGjUC4Pvvv2fw4MHMmTOHypUr+7/z9ttvs337dpKSkhg7diy33347zz77LCLC9ddf7287kt69SOZjnzlzJp06dfLfEaWlpfHuu+9meD4QbFvpd3vgiv6s9bAHTp3yrOdRwNM7gqLAFiASuAj4AYjOtM7HwB98nxvjnhFIsO3m9zsCVXcXUL9+fe3UqZP26tXLf0egqnrPPfdoqVKl/Ffa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\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": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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u8Jva2ujpaWFlpYWVq1aBcANN9zAihUraG5u5o477kjqodx888185jOfSZwrnYBQStHZ2cm9997L448/nmQ4ve2225gzZw5z585NVMCbN2/mjDPOYO7cubS0tLBlyxYAbr/9dk466SROOOEEbrrJnpVzaGiI8847j7lz5zJ79mx+85vfJMo9a9YsTjjhBL7yla8kyuu28AF+8Ytf0NzczOzZs3n22WcBuPfee/nCF76Qcg+XXnop999/P9/73vfYtm0bixYtYtGiRdx9991cc801iXw//elPufbaazP82zmglCpJAo4CNqTZ93vgw9r6k8B84CvA17Tt/wZ8Jdu15s2bpwy1Q1tbm6qrq1OAqqurU21tbeNdpKJ56aWX8srf29ur2traVCgUUm1tbaq3t7eo6//nf/6nuuaaa3z3LVu2TIXDYfXmm2+qWCymFixYoFasWKGUUurII49Ut912m1JKqa1bt6oPfvCDavv27Wp4eFgtWrRIPfjgg0oppQD16KOPKqWUOv/889WZZ56p9u/fr6LRqJo7d65SSqmhoSH13nvvKaWU2rhxo3K/62XLlqnzzjsvqTzu+k033aRaW1vV3r171Y4dO9TBBx+s9u/fn3IPK1euVKeffrpSSqlPfOIT6v7771dKKfXoo4+q1tZWNTQ0pJRSaufOnUoppU4++WT1wAMPKKWUeu+999TQ0JB67LHH1Gc/+1kVj8dVLBZT5513nlq+fLm6//771RVXXJG41q5du9Q777yjZs6cqeLxuFJKqb/97W+J8t5+++1KKaVOPfXUxHHLly9Xxx9/vFJKqXvuuUddffXVKfkvueQS1dnZmXjuO3bsUEopNTAwoGbMmJG479bWVvXCCy+kPAO/dwxYo3zq1LHqEWwFPqitT3e2pdtuMCTo7OyktbWVUChEa2srnTXYG+jo6KC7u5uBgQG6u7vpKLOx/OSTT2b69OkEAgGam5t5/fXXE/v+6Z/+CYDnnnuO0047jalTp1JXV8cnP/lJurq6AJg0aRJnn21reefMmcOpp55KfX09c+bMSZxreHiYz372s8yZM4eOjg5eeumlnMp23nnnMXnyZA455BAOPfRQX3XW0qVLuegie1rmiy66KKEeeuKJJ7jssstoaGgA4OCDD2ZgYICtW7fyj//4j4A9GKuhoYE///nP/PnPf+bEE0+kpaWFV155hU2bNjFnzhwef/xxrr/+elasWMGBBx7IgQceyJQpU7j88st54IEHEuf38olPfAKA9vZ2+vv72bVrV073rBMMBjn99NP5/e9/zyuvvMLw8DBz5szJ+zw6YzWg7BHgCyLya2zD8G6l1Nsi8hjwTc1A/FFGJwk3GABoampKVDC1SjQaZcQxlo+MjBAt0lh+/PHHc//996fdP3ny5MSyZVmJawM0NjZmPX99fX3ChTEQCCTOFwgEEue64447aGpqYv369cTjcaZMmZJT2TOVDWzbxe9+9zsefvhhvvGNbyQGWA0MDOR0fhelFDfeeCOf+9znUvatW7eORx99lK997Wt85CMf4etf/zrPPvssTz75JPfffz/f//73+ctf/pJynNets1AX4iuuuIJvfvObHHfccVx22WUFnUOnVO6jS7FVuB8SkbdE5HIR+byIuArIR4HXgM3AT4GrAJRS7wL/DjznpFucbQaDQaO5uZm6OrvdVldXR3ORxvLTTz+dffv28ZOf/CSx7YUXXmDFihU5n+Pkk09m+fLlvPPOO8RiMZYuXcqpp56a8/G7d+/msMMOIxAI8Itf/CJhfA6FQnlX2jpPPvkkJ5xwAm+++Savv/46b7zxBhdccAEPPvggZ555Jvfcc0/C8Pruu+8SCoWYPn06Dz30EAD79u1jz549nHXWWdx9990MDg4CsHXrVrZv3862bdtoaGjgU5/6FNdddx3r1q1jcHCQ3bt3c+6553LHHXewfv1637K59oSVK1cmehK54H0mkUiEN998k1/96leJXkYxlKRHoJTKWBJHN3V1mn13A3eXohwGQwp9ffaYg2jU9jTq7ISmpvEuVd50dnbS0dFBNBqlubm5aPWYiPDggw9yzTXXcNtttzFlyhSOOuoo7rzzTrZuzU07e9hhh/Htb3+bRYsWoZTivPPOY8mSJTmX4aqrruKCCy7gvvvu4+yzz070NE444QQsy2Lu3LlceumlnHjiiXnd29KlSxNqHpcLLriAu+66iz/+8Y9Eo1Hmz5/PpEmTOPfcc/nmN7/JL37xCz73uc/x9a9/nfr6ejo7O/noRz/Kyy+/TGtrK2CrZH75y1+yefNmrrvuOgKBAPX19dx1110MDAywZMkS9u7di1KK//iP//At25QpUzjxxBMZHh7m7rtzr/auvPJKzj77bKZNm8ayZcsA+PjHP040GuWgg0rgce9nOKj0ZIzFNUJvr1KRiFKBgFKWZS97jaS9vUq1tSkVCtm/vb2j2xob7ePATpZlb68A8jUWGwxezjvvPPXEE0+k3V+JxmKDIX86OmD1aojHIRazl2fOtFv5bsiJadNgxYrREcczZ8Lhh9vbhobs41xisdSBaGMZukK/Vm8vDA9nP8Zg8LBr1y5mzpzJAQccwEc+8pGSnNNEHzVULn4G0f7+0fAS3d22kHAZGUH195PR/CZiV8SumsgNXTEyMhq6olyGaf1a+/bBli1w3HHluZZhwvK+972PjRs3lvScpkdgqFzSGUSfftpOHm8RBZmFQCBgC5KBAbvHsGSJLWz00BWrVpWud+Dtbaxbl1zmMo4UNRjywQgCw/iyYQOEQnZLXQQaG+319na45hqUzyEqHkfpPQEHrxBQwKBlMQi8GAymHvPcc7awqdM6xrGYLShWrSo+sJ03UJ5lJV8rja+5wTDWGEFgGF8WLgTHPQ+wW8mDg3ZF/PGP+x4iZGn5u6fC9ilvBD6kX8MlHrd7Fj5ChVjM7jXk2TPo6+ujvb2dcDicGigvHofWVlvQTZ4MxxyT83kNhnJiBIFhbOnrgwULRlvH/f3++WIxVCyWVOErz68X5VluAMLYQsMC33ORpneRoLvbViHlaFDWRwCvi8VIKILq6uDEE237Q38/fOADkOM0ggZDuTGCwDC2eD2BsqBX7uL59SI+y/qvLkj88voyMgJr1uQ8F4I+AvhCnAB5oZDdE6iw0Bh9fX388z//MzNmzGDevHm0trby4IMPlvWaN998M4cffjjNzc2JVEiYhXKgh32uNYzXkKH06IO4Zs2yt730EjQ3E1+7NqX14VbQ3grZrbyzGoG1fPq5vT2AGLa6SDHaU9D3CXYIBGlogPfeswVVXV2y0MoyF0JzczPd3d2MjIzwbl0dN7a2VmR4DKUU559/Ppdcckki5PMbb7yRiAxaTq699tpEdM5SMDIykhh1XQy33HJLCUpTnZgegaH06EbS1avt5LSm9+7dm6La8er8/VruXrWPn3po0LNPefJfCESxX3pvT+M9YEpdHacuXAibN8Mpp4y25E86adTIW1eXcS6EagmQ95e//IVJkyYlhaE+8sgj+eIXvwjYtpXrrrsuEYL5xz/+MQBPPfUUp512mm+I6rVr13Lqqacyb948zjrrLN5+++2cy3PHHXfwmc98BoCenh5mz57Nnj17uPnmm7n44otpbW3l2GOP5ac//WmiHG1tbSxevJhZs2alLe/bb79Ne3t7IvTzihUriMViXHrppcyePZs5c+Zwxx13AKNhn8EOU3HiiScyZ84cPvOZz7Bv3z7ADsN900030dLSwpw5c3jllVcK/g8qCr9RZpWezMjiccQdtRsM2slv1G8oNDqa15PiTkq3v5g8/RmOi4OKOcl7/H5Qyx15YVlWIsTz9p4eFQ2H1QCoActSscbG0dHLRZL3yGK/EdRFkCkMtVJK/fjHP1b//u//rpRSau/evWrevHnqtddeSxuiev/+/aq1tVVt375dKaXUr3/9a3XZZZelnPemm25S06ZNU3PnzlVz585Vp512mlJKqVgsptra2tQDDzyg5s2bp1auXJnIf8IJJ6g9e/aoHTt2qOnTp6utW7eqZcuWqYaGBvXaa69lLO93v/tddeuttyqllBoZGVH9/f1qzZo16owzzkiUyQ0Z7YZ9fu+999T06dPVq6++qpRS6uKLL1Z33HGHUsoOB/29731PKaXUD37wA3X55Zfn//DHCDOy2FA+liyxvWkGB+2kj/p1deeaS2bcSUDCcFpIvMVcehHpjMhu/gCjXWD3eIWtLnK1/rFYLBHiedvChczq7ycITI7F6N67l3A0SntHR14zeZWEMs/ZfPXVVzN37lxOOukkAP785z9z33330dzcTCQSYefOnWzatAnwD1H96quvsmHDBs4880yam5u59dZbeeutt3yvde211xKNRolGo4m4OYFAgHvvvZeLL76YU089lYULFybyL1myhAMOOIBDDjmERYsWJSZ0Ofnkkzn66KMzlvekk07innvu4eabb6anp4dQKMSMGTN47bXX+OIXv8if/vQnwuFwUvleffVVjj76aGbOnAnAJZdckqTe+9jHPgbAvHnzksJzVzPGRmDIj+eeS78vGqWvr48r9+/nX+Nx5gAvOrtmYwuEMLnp/NPZC7yVv7s9BjSm2Z/tOgGgE2jGVh19Ze1aaG/nBG2Ucj0wJxZLmg9gTHX/3oFvJQhD/bvf/S6x/oMf/IB33nmH+fPnA7am4L/+678466yzko576qmnfMNAK6U4/vjj6e7uLrhMmzZtIhgMsm3btqTt6UI36+Gw05UXoKuriz/84Q9ceumlfPnLX+bTn/4069ev57HHHuNHP/oR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\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), 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()"
   ]
  }
 ],
 "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
}
