{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Unbalanced Gromov-Wasserstein for SNARE-seq example\n",
    "\n",
    "To simulate imbalance between cell types, we subsample the ATAC dataset and try to align to the full RNA dataset."
   ]
  },
  {
   "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",
    "from sklearn.cluster import SpectralClustering\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.decomposition import PCA\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": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "X=ut.unit_normalize(X)\n",
    "y=ut.unit_normalize(y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Can't find the cell-type information for now, so assign cluster labels based on spectral clustering. This seems relatively clean..."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fa9b1c14890>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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": [
    "pca=PCA(n_components=2)\n",
    "y_pca = pca.fit_transform(y)\n",
    "\n",
    "clustering = SpectralClustering(n_clusters = 4, assign_labels = \"discretize\", random_state = 0).fit(y_pca)\n",
    "plt.scatter(y_pca[:, 0], y_pca[:, 1], s = 4, c = clustering.labels_)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Now subsample the ATAC data according to class proportions `props`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fa9aaab6ad0>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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": [
    "props = [0.5, 1, 0.75, 0.5]\n",
    "index = np.concatenate([np.where(clustering.labels_ == i)[0][0:int((clustering.labels_ == i).sum() * props[i])] for i in range(len(props))])\n",
    "X_subsamp = X[index, :]\n",
    "\n",
    "X_subsamp_pca = pca.fit_transform(X_subsamp)\n",
    "plt.scatter(X_subsamp_pca[:, 0], X_subsamp_pca[:, 1], s = 4, c = clustering.labels_[index])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# initialize SCOT object\n",
    "scot=sc.SCOT(X_subsamp, y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Align using balanced and unbalanced Gromov-Wasserstein"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "It.  |Err         \n",
      "-------------------\n",
      "    0|2.512857e-03|\n",
      "   10|9.632699e-04|\n",
      "   20|2.201648e-04|\n",
      "   30|9.146903e-05|\n",
      "   40|5.387046e-05|\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-8-f2a3e27147fa>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;31m# call the unbalanced alignment\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mX_new_bal\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my_new_bal\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mscot\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0malign\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m50\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0.0005\u001b[0m\u001b[0;34m,\u001b[0m  \u001b[0mnormalize\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/Documents/ManifoldAlignment/SCOT-master/src/scot2.py\u001b[0m in \u001b[0;36malign\u001b[0;34m(self, k, e, balanced, rho, verbose, normalize, norm, XontoY)\u001b[0m\n\u001b[1;32m    196\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbuild_kNN\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    197\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcompute_graphDistances\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 198\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfind_correspondences\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0me\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0me\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbalanced\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mbalanced\u001b[0m\u001b[0;34m,\u001b[0m  \u001b[0mrho\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mrho\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mverbose\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mverbose\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    199\u001b[0m         \u001b[0mX_aligned\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my_aligned\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbarycentric_projection\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mXontoY\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    200\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mX_aligned\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my_aligned\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Documents/ManifoldAlignment/SCOT-master/src/scot2.py\u001b[0m in \u001b[0;36mfind_correspondences\u001b[0;34m(self, e, balanced, rho, verbose)\u001b[0m\n\u001b[1;32m    162\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mflag\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    163\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mbalanced\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 164\u001b[0;31m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcoupling\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlog\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mot\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgromov\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mentropic_gromov_wasserstein\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mCx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mCy\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mp\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mq\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'square_loss'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mepsilon\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0me\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlog\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mverbose\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mverbose\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    165\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgwdist\u001b[0m\u001b[0;34m=\u001b[0m \u001b[0mlog\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'gw_dist'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    166\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/ot/gromov.py\u001b[0m in \u001b[0;36mentropic_gromov_wasserstein\u001b[0;34m(C1, C2, p, q, loss_fun, epsilon, max_iter, tol, verbose, log)\u001b[0m\n\u001b[1;32m    655\u001b[0m         \u001b[0mtens\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mgwggrad\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mconstC\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhC1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhC2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mT\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    656\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 657\u001b[0;31m         \u001b[0mT\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msinkhorn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mp\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mq\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtens\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mepsilon\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    658\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    659\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mcpt\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0;36m10\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/ot/bregman.py\u001b[0m in \u001b[0;36msinkhorn\u001b[0;34m(a, b, M, reg, method, numItermax, stopThr, verbose, log, **kwargs)\u001b[0m\n\u001b[1;32m    112\u001b[0m         return sinkhorn_knopp(a, b, M, reg, numItermax=numItermax,\n\u001b[1;32m    113\u001b[0m                               \u001b[0mstopThr\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mstopThr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mverbose\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mverbose\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlog\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 114\u001b[0;31m                               **kwargs)\n\u001b[0m\u001b[1;32m    115\u001b[0m     \u001b[0;32melif\u001b[0m \u001b[0mmethod\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlower\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;34m'greenkhorn'\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    116\u001b[0m         return greenkhorn(a, b, M, reg, numItermax=numItermax,\n",
      "\u001b[0;32m~/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/ot/bregman.py\u001b[0m in \u001b[0;36msinkhorn_knopp\u001b[0;34m(a, b, M, reg, numItermax, stopThr, verbose, log, **kwargs)\u001b[0m\n\u001b[1;32m    362\u001b[0m         \u001b[0mKtransposeU\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mK\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mu\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    363\u001b[0m         \u001b[0mv\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdivide\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mb\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mKtransposeU\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 364\u001b[0;31m         \u001b[0mu\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m1.\u001b[0m \u001b[0;34m/\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mKp\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mv\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    365\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    366\u001b[0m         if (np.any(KtransposeU == 0)\n",
      "\u001b[0;32m<__array_function__ internals>\u001b[0m in \u001b[0;36mdot\u001b[0;34m(*args, **kwargs)\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "# call the unbalanced alignment \n",
    "X_new_bal, y_new_bal = scot.align(k=50, e=0.0005,  normalize=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "It.  |Err         \n",
      "-------------------\n",
      "    0|1.104449e-03|\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rebecca/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/ot/unbalanced.py:394: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  u = (a / Kv) ** fi\n",
      "/home/rebecca/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/ot/unbalanced.py:403: UserWarning: Numerical errors at iteration 0\n",
      "  warnings.warn('Numerical errors at iteration %s' % i)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   10|0.000000e+00|\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "../src/scot2.py:183: RuntimeWarning: invalid value encountered in true_divide\n",
      "  self.coupling=self.coupling / np.sum(self.coupling)\n"
     ]
    }
   ],
   "source": [
    "X_new_unbal, y_new_unbal = scot.align(k=50, e=1e-3, rho = 0.0005, normalize=False, balanced = False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We have aligned the ATAC dataset (subsampled) onto the RNA dataset (full)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "Input contains NaN, infinity or a value too large for dtype('float64').",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-13-0ea07d3cb613>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0mX_pca_bal\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mXy_pca_bal\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mX_new_bal\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0my_pca_bal\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mXy_pca_bal\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mX_new_bal\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 5\u001b[0;31m \u001b[0mXy_pca_unbal\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mpca\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfit_transform\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mconcatenate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX_new_unbal\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my_new\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0maxis\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      6\u001b[0m \u001b[0mX_pca_unbal\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mXy_pca_unbal\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mX_new_unbal\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      7\u001b[0m \u001b[0my_pca_unbal\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mXy_pca_unbal\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mX_new_unbal\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/sklearn/decomposition/_pca.py\u001b[0m in \u001b[0;36mfit_transform\u001b[0;34m(self, X, y)\u001b[0m\n\u001b[1;32m    374\u001b[0m         \u001b[0mC\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0mordered\u001b[0m \u001b[0marray\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0muse\u001b[0m \u001b[0;34m'np.ascontiguousarray'\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    375\u001b[0m         \"\"\"\n\u001b[0;32m--> 376\u001b[0;31m         \u001b[0mU\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mS\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mV\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_fit\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    377\u001b[0m         \u001b[0mU\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mU\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mn_components_\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    378\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/sklearn/decomposition/_pca.py\u001b[0m in \u001b[0;36m_fit\u001b[0;34m(self, X)\u001b[0m\n\u001b[1;32m    396\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    397\u001b[0m         X = self._validate_data(X, dtype=[np.float64, np.float32],\n\u001b[0;32m--> 398\u001b[0;31m                                 ensure_2d=True, copy=self.copy)\n\u001b[0m\u001b[1;32m    399\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    400\u001b[0m         \u001b[0;31m# Handle n_components==None\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/sklearn/base.py\u001b[0m in \u001b[0;36m_validate_data\u001b[0;34m(self, X, y, reset, validate_separately, **check_params)\u001b[0m\n\u001b[1;32m    418\u001b[0m                     \u001b[0;34mf\"requires y to be passed, but the target y is None.\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    419\u001b[0m                 )\n\u001b[0;32m--> 420\u001b[0;31m             \u001b[0mX\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcheck_array\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mcheck_params\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    421\u001b[0m             \u001b[0mout\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mX\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    422\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/sklearn/utils/validation.py\u001b[0m in \u001b[0;36minner_f\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m     70\u001b[0m                           FutureWarning)\n\u001b[1;32m     71\u001b[0m         \u001b[0mkwargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mupdate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m{\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0marg\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0marg\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msig\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mparameters\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 72\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     73\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0minner_f\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     74\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/sklearn/utils/validation.py\u001b[0m in \u001b[0;36mcheck_array\u001b[0;34m(array, accept_sparse, accept_large_sparse, dtype, order, copy, force_all_finite, ensure_2d, allow_nd, ensure_min_samples, ensure_min_features, estimator)\u001b[0m\n\u001b[1;32m    643\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mforce_all_finite\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    644\u001b[0m             _assert_all_finite(array,\n\u001b[0;32m--> 645\u001b[0;31m                                allow_nan=force_all_finite == 'allow-nan')\n\u001b[0m\u001b[1;32m    646\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    647\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mensure_min_samples\u001b[0m \u001b[0;34m>\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Documents/ManifoldAlignment/venv/lib/python3.7/site-packages/sklearn/utils/validation.py\u001b[0m in \u001b[0;36m_assert_all_finite\u001b[0;34m(X, allow_nan, msg_dtype)\u001b[0m\n\u001b[1;32m     97\u001b[0m                     \u001b[0mmsg_err\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     98\u001b[0m                     (type_err,\n\u001b[0;32m---> 99\u001b[0;31m                      msg_dtype if msg_dtype is not None else X.dtype)\n\u001b[0m\u001b[1;32m    100\u001b[0m             )\n\u001b[1;32m    101\u001b[0m     \u001b[0;31m# for object dtype data, we only check for NaNs (GH-13254)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mValueError\u001b[0m: Input contains NaN, infinity or a value too large for dtype('float64')."
     ]
    }
   ],
   "source": [
    "pca=PCA(n_components=2)\n",
    "Xy_pca_bal=pca.fit_transform(np.concatenate((X_new_bal, y_new), axis=0))\n",
    "X_pca_bal=Xy_pca_bal[0:X_new_bal.shape[0],]\n",
    "y_pca_bal=Xy_pca_bal[X_new_bal.shape[0]:,]\n",
    "Xy_pca_unbal=pca.fit_transform(np.concatenate((X_new_unbal, y_new), axis=0))\n",
    "X_pca_unbal=Xy_pca_unbal[0:X_new_unbal.shape[0],]\n",
    "y_pca_unbal=Xy_pca_unbal[X_new_unbal.shape[0]:,]\n",
    "\n",
    "### Read in cell type information:\n",
    "# Xlabels=np.genfromtxt(\"data/SNAREseq_typesChromatin.txt\")\n",
    "# ylabels=np.genfromtxt(\"data/SNAREseq_typesExpression.txt\")\n",
    "\n",
    "fig, (ax1, ax2, ax3) = plt.subplots(1, 3, figsize = (15, 5))\n",
    "ax1.scatter(y_pca_bal[:,0], y_pca_bal[:,1], s=15, label=\"Gene Expression\", alpha = 0.5, c = clustering.labels_, marker = \"+\")\n",
    "ax1.set_title(\"Expression\")\n",
    "\n",
    "ax2.scatter(X_pca_unbal[:,0], X_pca_unbal[:,1], s=15, label=\"Chromatin Accessibility\", alpha = 0.5, c = clustering.labels_[index], marker = \"^\")\n",
    "ax2.set_title(\"ATAC, unbalanced\")\n",
    "\n",
    "ax3.scatter(X_pca_bal[:,0], X_pca_bal[:,1], s=15, label=\"Chromatin Accessibility\", alpha = 0.5, c = clustering.labels_[index], marker = \"^\")\n",
    "ax3.set_title(\"ATAC, balanced\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "For a (row-normalised) coupling $P$, we can compute the expected class membership error:\n",
    "$$\\mathbf{E}_{(x, y) \\sim P} \\mathbf{1}\\{ \\mathrm{class}(x) \\ne \\mathrm{class}(y) \\}$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [],
   "source": [
    "P_unbal = (gamma_unbal.T/gamma_unbal.sum(1)).T\n",
    "mean_err_unbal = (P_unbal*(clustering.labels_[index, None] != clustering.labels_[None, :])).sum(1).mean()\n",
    "P_bal = (gamma_bal.T/gamma_bal.sum(1)).T\n",
    "mean_err_bal = (P_bal*(clustering.labels_[index, None] != clustering.labels_[None, :])).sum(1).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "unbalanced: 0.138904, balanced: 0.254218\n"
     ]
    }
   ],
   "source": [
    "print(\"unbalanced: %f, balanced: %f\" % (mean_err_unbal, mean_err_bal))"
   ]
  }
 ],
 "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.7.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
