{
 "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": 19,
   "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": 20,
   "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": 21,
   "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": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average FOSCTTM score for this alignment is:  0.1918817411402157\n"
     ]
    }
   ],
   "source": [
    "fracs=evals.calc_domainAveraged_FOSCTTM(X_new, y_new[0])\n",
    "print(\"Average FOSCTTM score for this alignment is: \", np.mean(fracs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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[0]), 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"
   ]
  },
  {
   "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
}
