{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Notebook for running SCOT on scGEM 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",
    "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=  (177, 27)  y=  (177, 34)\n"
     ]
    }
   ],
   "source": [
    "X=np.genfromtxt(\"../data/scGEM_methylation.csv\", delimiter=\",\")\n",
    "y=np.genfromtxt(\"../data/scGEM_expression.csv\", delimiter=\",\")\n",
    "print(\"Dimensions of input datasets are: \", \"X= \", X.shape, \" y= \", y.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "It.  |Err         \n",
      "-------------------\n",
      "    0|5.587079e-03|\n",
      "   10|7.742081e-05|\n",
      "   20|6.302990e-06|\n",
      "   30|7.716994e-07|\n",
      "   40|9.942395e-08|\n",
      "   50|1.301204e-08|\n",
      "   60|1.712430e-09|\n",
      "   70|2.258163e-10|\n"
     ]
    }
   ],
   "source": [
    "# initialize SCOT object\n",
    "scot=sc.SCOT(X, y)\n",
    "# call the alignment with z-score normalization \n",
    "X_new, y_new = scot.align( k=35, e=5e-3,  normalize=True, norm=\"l2\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Evaluating Alignment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 0.        ,  0.        ,  0.        , ..., 14.18100147,\n",
       "         0.        ,  0.        ],\n",
       "       [ 0.        ,  0.        ,  0.        , ...,  0.        ,\n",
       "         4.36092358, 17.15145564],\n",
       "       [ 0.        ,  0.        ,  0.        , ...,  0.        ,\n",
       "         0.        , 17.92379111],\n",
       "       ...,\n",
       "       [21.41140091, 18.05862762, 20.64271902, ..., 17.35320788,\n",
       "         5.20370676, 18.95157826],\n",
       "       [20.73124401, 18.77626135, 20.59555481, ..., 14.68086341,\n",
       "         8.26569129, 19.70335222],\n",
       "       [20.86118177, 18.7454412 , 20.73805   , ...,  0.        ,\n",
       "         0.        , 18.77453712]])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average FOSCTTM score for this alignment is:  0.19433744221879815\n"
     ]
    }
   ],
   "source": [
    "fracs=evals.calc_domainAveraged_FOSCTTM(X_new, y_new)\n",
    "print(\"Average FOSCTTM score for this alignment is: \", np.mean(fracs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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sIGOHTvSsmVLWrdu7R+7KDcff/wx7du3p1KlSlSsWJH27dvzv//976T9MpvKZrd69Wp/h7Hzzz+f8847j8zWZfv37+ell17isccey/KawE5+Bw4c8HeUK1++vP954PpA06dPp1OnTpQtWxZwvamHDBnC888/f9K+jz/+OEOHDqV0QGuPFi1a+Mc+atKkCQcPHuTw4cOULVvW3+O7ZMmSxMfHk5aWBri/h2bNmvk7IGYSEQ4dOsSRI0c4fPgwR48e5YILLsiyz/r169m2bRutW7c+6XpdddVVfPDBB6c8VmJiYpYe46bo8DQRiEhHEVknIikiMiyH7S+LyDLfY72I7PYynoIyYsQIkpKSWLFiBQsXLmTFihVcc801fPvttxzwDR71/vvv06tXL3bs2MEzzzzDp59+ytKlS0lISOCll17yH6ty5cosXbqUXr16ceONN7JkyRKWL19O48aN/X0O7r//fu6//35WrlxJzZo1/a+dN28eP/74I9999x3Lli0jOTmZL774IkusN910k3+IisC44PTGMcpuwIABvP766yQnJzNq1CjuueceAObMmcPw4cNP2j89PZ1atWr5l2vWrEl6enqez9e8eXPmzJlDRkYGP/30E8nJyWzatAlwH8QPPfSQ/0M70KOPPkqtWrWYNGmSv38HwKxZs2jUqBFdunRh/PjxJ71uypQpWTqTjR49mq5du570Qbl06VI2bdpEly5dco19xowZxMfH+3tgZ9q9ezcffvghV199ddD3ftlll3HVVVdRrVo1qlWrRocOHU5qppk5JlJmUmvevLl/GJFZs2axb98+du7cmadj5fYemjVrxs033+y/7iYfDRgAAQNU5jfPEoGIRAFjgE5ADNBbRLKMnaCqD6hqnKrGAa8DM086UCE0depU4uPjadGiBatWrWL16tUUL16cjh078uGHH5KRkcF//vMfunXrxjfffMPq1au54ooriIuLY+LEifz888/+YwV2tPrhhx9o3bo1sbGxTJo0yd97d/Hixf67jVtvvdW//7x585g3bx4tWrQgPj6etWvXZukBDVC1alUuuugivvnmG3bu3MnatWu54go3e+hrr71G8+bNSUxM9I9jlBf79+/n66+/pkePHsTFxXHXXXf5RyPt2rVrlg/c/HLnnXdSs2ZNEhISGDx4MJdffjlRUVEsW7aMDRs20L179xxfN2LECDZt2sRtt93G6NGj/eu7d+/O2rVrmT17dpYRYsGNNrty5Uo6dOgAwObNm5k2bRqDBg3Kst/x48d58MEHefHFF3ONe9WqVQwdOjTL3AngBurr3bs39913HxdddFHQ956SksKaNWtIS0sjPT2dzz77jEWLFmXZJ3viGjVqFAsXLqRFixYsXLiQGjVqEBUVladjZXf99deTmprKihUraN++PX379g26vzkDX34Jp7irPhteNh9tBaSo6kYAEZkCdANW57J/b+DksotC5qeffmLUqFEsWbKEihUr0q9fP//4P7169WL06NFUqlSJhIQEzjnnHFSV9u3bM3ny5ByPVy5gtMF+/foxe/ZsmjdvzoQJE07ZFFRVeeSRR7jrrruC7terVy+mTp1Ko0aN6N69OyKSp3GMihcv7h/hE/BvP378OOeddx7Lli0Let5ANWrUyPJ+0tLSaJtTM+BcFC9enJdfftm/fPnll9OgQQMWLlxIUlISdevWJSMjg23bttG2bduTrt1tt91G586deeqpp7Ks/8Mf/sDGjRvZsWOHf/jrqVOn0r17d0qUKAHA999/T0pKin9okN9//5169eqRnJzMDz/84H8fW7ZsoWvXrsyZM4eEhATS0tLo3r077777rr93eaYBAwZQv359Bg8efMr3PmvWLBITE/1Fgp06dWLx4sX+YqDly5eTkZGRZQTW6tWr++8I9u/fz4wZMzjvvPMYN25c0GPlJHCQwz/+8Y88/PDDp4zZnCaPWw15WTRUAwi8R0zzrTuJiNQBooHPctk+QESSRCQp3CfA3rt3L+XKlaNChQps3brVPxsZQJs2bVi6dCnjxo3zF78kJiby1VdfkZKSArgy6fXr1+d47H379lGtWjWOHj3KpEmT/OsTExOZMWMGgH+cfIAOHTowfvx4f51Deno627ZtO+m43bt354MPPmDy5Mn+uPIyjtEFF1zAtm3b2LlzJ4cPH/aPFnruuecSHR3NtGnTAJeQli9fHvS6dejQgXnz5rFr1y527drFvHnz/N+48+L333/3F7t98sknFC9enJiYGO6++242b95MamoqX375JQ0aNPAngcA7nA8++IBGjRoB7hu2+nrcL126lMOHD2f5sJs8eXKWb9ddunRhy5YtpKamkpqaStmyZUlJSaFChQrs2LHDvz4xMdGfBHbv3k2XLl0YOXKk/w4s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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": [
    "### Visualizing Alignment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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er34fD6GDh3KyJEj+dnPfhbyjV++fDlCCP72t7+F2n/uc59j+fLloeeHDh0iNzeX3/3ud473uOSSSzjzzDNDCeMApk+fTlFRUdS+HTlyhPnz54eeL1++nM997nMxvb9BgwZx6NChqG1+8pOfhD2/6KKLYrpH2rJsbmQ9YJXeQdEFpJcA6MT0Dt1Nfn4+dXV1bNu2jVdffZWXXnqJH/7wh6HzAwcO5Mc//rHj66urqykvL+e5556Lep9evXqxevVqQJvY3WQJtQqAzsIqANasWdPp90wJnNI4qPQOik4mvQRAJ6Z3iIlOVkWdeuqpPPHEE/z6178OrdZHjhxJaWkpr776qu1rnnvuOX72s59RX1/vmPgN4LrrruP5558H4IUXXgglUzOYN29eKI3zAw88AMCsWbN4//338fl83H333QA0NTVFpKF+/fXXmT59euhar776Kl/4whci+jB9+nTGjBnD0KFDeeKJJ0L3aGlpwefzceONmnONsTORUnL33XeHUkYvWLAAiJ4OO63oKL3D5oVa2uc5vVT6Z0VykVKm5N+YMWNkBAcOSDlpkpTFxdr/AwfcneuA7du3u24rpdSun5MjJWj/J02K7fU2FBYWRhwrLS2VBw4ckG+88Ya8+uqr5b///W9ZWVkppZTy6quvlm+88YaUUsoPPvhAnnvuuVJKKe+77z7505/+1PYeF198sVy7dq0cPny49Pv98oorrpC7d+8O3fvll1+WX//612UwGJSBQCB0z927d8uhQ4eGrvPGG2/IkpIS+eGHH8pAICDLy8vlypUrZTAYlOeff7786KOPpJRSXn/99XLp0qVSSinPOussefDgQSmllIcPH5ZSStnc3CyHDh0qDx06ZPsZGM8XLVokL7/8cun3++WBAwfkGWecIfft2+fYDzvsvmNgvUyFsf3WAikfLJPygZL2vwfLtOPRzikUNsQyrtNrB2DO+79ihfbcoCvtA92kijLy8axatSrs+IIFC5gxQ/MYue6666KqgbxeLxMnTuT555+npaWFQYMGhc698sorvPLKK4waNYrRo0fzzjvvhNJOW7FLQy2E4Ctf+QrPPPMMR44coaamhquuuiritY8//jgjR46kvLycDz/80PEeBqtWreL666/H6/VSVlbGxRdfzLp16xz7kXYYef9LzwCE9v/zj2vHlX1A0YmkX0lIJ7pyUjaX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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 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: 177,]\n",
    "y_pca=Xy_pca[177:,]\n",
    "\n",
    "fig, (ax1, ax2) = plt.subplots(1, 2)\n",
    "ax1.scatter(X_pca[:,0], X_pca[:,1], c=\"k\", s=15, label=\"Gene Expression\")\n",
    "ax1.scatter(y_pca[:,0], y_pca[:,1], c=\"r\", s=15, label=\"DNA Methylation\")\n",
    "ax1.legend()\n",
    "ax1.set_title(\"Colored based on domains\")\n",
    "\n",
    "ax2.scatter(X_pca[:,0], X_pca[:,1], cmap=\"rainbow\")# , c=Xlabels, s=15)\n",
    "ax2.scatter(y_pca[:,0], y_pca[:,1], cmap=\"rainbow\")# , c=ylabels, s=15)\n",
    "ax2.set_title(\"Colored based on cell type\")\n",
    "plt.show()\n"
   ]
  }
 ],
 "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
}
