{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Zebrafish lineages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ag16115/anaconda3/lib/python3.8/site-packages/scipy/__init__.py:138: UserWarning: A NumPy version >=1.16.5 and <1.23.0 is required for this version of SciPy (detected version 1.23.1)\n",
      "  warnings.warn(f\"A NumPy version >={np_minversion} and <{np_maxversion} is required for this version of \"\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as pl\n",
    "import scanpy as sc\n",
    "\n",
    "sc.settings.verbosity = 2  # verbosity: errors (0), warnings (1), info (2), hints (3)\n",
    "sc.settings.set_figure_params(dpi=150)  # low dpi (dots per inch) yields small inline figures\n",
    "# sc.logging.print_versions()\n",
    "# results_file = './write/planaria_pp.h5ad'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy import linalg\n",
    "from scipy import sparse\n",
    "from scipy.sparse.linalg import svds\n",
    "import ot\n",
    "\n",
    "\n",
    "from numpy.linalg import matrix_rank\n",
    "import itertools\n",
    "import copy\n",
    "import time as time\n",
    "from sklearn.cluster import AgglomerativeClustering\n",
    "from matplotlib.pyplot import figure\n",
    "from scipy.cluster.hierarchy import dendrogram, fcluster, cophenet\n",
    "from scipy.spatial.distance import pdist,squareform\n",
    "import plotly.graph_objects as go\n",
    "from plotly.subplots import make_subplots\n",
    "\n",
    "from tqdm import tqdm\n",
    "from sklearn.metrics import pairwise_distances\n",
    "from sklearn.metrics.pairwise import cosine_similarity\n",
    "from sklearn.metrics.cluster import adjusted_rand_score, fowlkes_mallows_score\n",
    "from scipy.stats import rankdata,kendalltau,sem\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as mtick\n",
    "from sklearn.manifold import TSNE\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import random \n",
    "random.seed(22)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Functions"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## General"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def signif(x, p):\n",
    "    x = np.asarray(x)\n",
    "    x_positive = np.where(np.isfinite(x) & (x != 0), np.abs(x), 10**(p-1))\n",
    "    mags = 10 ** (p - 1 - np.floor(np.log10(x_positive)))\n",
    "    return np.round(x * mags) / mags\n",
    "\n",
    "def flatten_list(l):\n",
    "    flat_list = [item for sublist in l for item in sublist]\n",
    "    return flat_list\n",
    "\n",
    "def check_symmetric(a, rtol=1e-05, atol=1e-08):\n",
    "    return np.allclose(a, a.T, rtol=rtol, atol=atol)\n",
    "\n",
    "def is_pos_def(x):\n",
    "    return np.all(np.linalg.eigvals(x) > 0)\n",
    "\n",
    "def reverse_dict(dic):\n",
    "    for r in dic.keys():\n",
    "        if not isinstance(dic[r], list):\n",
    "            dic[r] = [dic[r]]\n",
    "    inverse = { v: k for k, l in dic.items() for v in l }\n",
    "    return inverse\n",
    "\n",
    "def pc_scores(X, r):\n",
    "    U, s, Vh = svds(X,k=r)\n",
    "    idx = s.argsort()[::-1]   \n",
    "    Vh = Vh[idx,:]\n",
    "    Y = X @ Vh.T\n",
    "    return Y\n",
    "\n",
    "def embed_cov(X, r):\n",
    "    if r == X.shape[0]:\n",
    "        U, s, Vh = np.linalg.svd(X, full_matrices=True)\n",
    "    else:\n",
    "        U, s, Vh = svds(X,k=r)\n",
    "    idx = s.argsort()[::-1]   \n",
    "    U = U[:,idx]\n",
    "    s = s[idx]\n",
    "    ## need to take square root as these are eigenvalues\n",
    "    Y = U @ np.diag(np.sqrt(s)) \n",
    "    return Y\n",
    "\n",
    "def find_rows_to_merge(F):\n",
    "    f = copy.deepcopy(F)\n",
    "    np.fill_diagonal(f, -np.inf)\n",
    "    i,j = np.unravel_index(f.argmax(), f.shape)\n",
    "    return [i,j]   \n",
    "\n",
    "def inner_products(X):\n",
    "    return X.dot(X.T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def wasserstein_dim_select(Y, split = 0.5, rmax = 50):\n",
    "    n = Y.shape[0]\n",
    "    train = round(n * split)\n",
    "    rtry = int(np.min((train, rmax)))\n",
    "    if sparse.issparse(Y):\n",
    "        Y = Y.todense()\n",
    "    Ytrain = Y[:train,:]\n",
    "    Ytest = Y[train:n,:]\n",
    "    U, s, Vh = sparse.linalg.svds(Ytrain,k=rtry-1)\n",
    "    idx = s.argsort()[::-1] \n",
    "    s = s[idx]\n",
    "    Vh = Vh[idx,:]\n",
    "    ws = []\n",
    "    for r in tqdm(range(1,rtry+1)):\n",
    "        P = Vh.T[:,:r] @ Vh[:r,:]\n",
    "        Yproj = Ytrain @ P.T\n",
    "        n1 = Yproj.shape[0]\n",
    "        n2 = Ytest.shape[0]\n",
    "        M = ot.dist(Yproj,Ytest, metric='euclidean')\n",
    "        W1 = ot.emd2(np.repeat(1/n1,n1),np.repeat(1/n2,n2),M)\n",
    "        ws.append(W1)\n",
    "    return ws"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## IP HC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# def ip_metric(X,Y):\n",
    "#     return  np.exp(-np.sum(X * Y))\n",
    "\n",
    "# def ip_affinity(X):\n",
    "#     return pairwise_distances(X, metric = ip_metric)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def ip_metric(X,Y):\n",
    "    return  np.sum(X * Y)\n",
    "\n",
    "def ip_affinity(X):\n",
    "    ips = pairwise_distances(X, metric = ip_metric)\n",
    "    return np.max(ips) - ips"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def clusters_to_labels(clusters):\n",
    "    d = defaultdict(list)\n",
    "    for index, sublist in enumerate(clusters):\n",
    "        for item in sublist:\n",
    "            d[item].append(index)\n",
    "    labels = flatten_list([d[c] for c in range(len(d.keys()))])\n",
    "    return labels"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Ranking"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_ancestors(model, target):\n",
    "    n_samples = len(model.labels_)\n",
    "    global ances\n",
    "    for ind, merge in enumerate(model.children_):\n",
    "        if target in merge:\n",
    "            if n_samples+ind in ances:\n",
    "                return [target]+ ances[n_samples+ind]\n",
    "            ances[n_samples+ind] = find_ancestors(model,n_samples+ind)\n",
    "            return [target]+ances[n_samples+ind]\n",
    "    return [ind+n_samples]\n",
    "\n",
    "def find_descendents(model,node):\n",
    "    n_samples = len(model.labels_)\n",
    "    global desc\n",
    "    if node in desc:\n",
    "        return desc[node]\n",
    "    if node < n_samples:\n",
    "        return [node]\n",
    "    pair = model.children_[node-n_samples]\n",
    "    desc[node] = find_descendents(model,pair[0])+find_descendents(model,pair[1])\n",
    "    return desc[node]\n",
    "\n",
    "def get_ranking(model, target):\n",
    "    rank = np.zeros(len(model.labels_))\n",
    "    to_root = [find_descendents(model, cl) for cl in find_ancestors(model, target)]\n",
    "    to_rank = [list(set(to_root[i+1]) - set(to_root[i])) for i in range(len(to_root)-1)]\n",
    "    for i in range(1,len(to_rank)+1):\n",
    "        rank[to_rank[i-1]] = i\n",
    "    return rank"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Dendrogram"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_dendrogram(model, rescale = False, size = (10,10), **kwargs):\n",
    "    # Create linkage matrix and then plot the dendrogram\n",
    "\n",
    "    # create the counts of samples under each node\n",
    "    counts = np.zeros(model.children_.shape[0])\n",
    "    n_samples = len(model.labels_)\n",
    "    for i, merge in enumerate(model.children_):\n",
    "        current_count = 0\n",
    "        for child_idx in merge:\n",
    "            if child_idx < n_samples:\n",
    "                current_count += 1  # leaf node\n",
    "            else:\n",
    "                current_count += counts[child_idx - n_samples]\n",
    "        counts[i] = current_count\n",
    "    \n",
    "    if rescale == True:\n",
    "        d_max = np.max(model.distances_)\n",
    "        d_min = np.min(model.distances_)\n",
    "        distances = (model.distances_ - d_min) / (d_max - d_min)\n",
    "    else:\n",
    "        distances = model.distances_\n",
    "\n",
    "    linkage_matrix = np.column_stack(\n",
    "        [model.children_, distances, counts]\n",
    "    ).astype(float)\n",
    "\n",
    "    # Plot the corresponding dendrogram\n",
    "    fig = plt.figure(figsize = size)\n",
    "    dendrogram(linkage_matrix, **kwargs)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def linkage_matrix(model, rescale = False):\n",
    "    # Create linkage matrix and then plot the dendrogram\n",
    "\n",
    "    # create the counts of samples under each node\n",
    "    counts = np.zeros(model.children_.shape[0])\n",
    "    n_samples = len(model.labels_)\n",
    "    for i, merge in enumerate(model.children_):\n",
    "        current_count = 0\n",
    "        for child_idx in merge:\n",
    "            if child_idx < n_samples:\n",
    "                current_count += 1  # leaf node\n",
    "            else:\n",
    "                current_count += counts[child_idx - n_samples]\n",
    "        counts[i] = current_count\n",
    "    \n",
    "    if rescale == True:\n",
    "        d_max = np.max(model.distances_)\n",
    "        d_min = np.min(model.distances_)\n",
    "        distances = (model.distances_ - d_min) / (d_max - d_min)\n",
    "    else:\n",
    "        distances = model.distances_\n",
    "\n",
    "    linkage_matrix = np.column_stack(\n",
    "        [model.children_, distances, counts]\n",
    "    ).astype(float)\n",
    "\n",
    "    return linkage_matrix\n",
    "\n",
    "def NormalizeData(data):\n",
    "    return (data - np.min(data)) / (np.max(data) - np.min(data))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Data load and preprocessing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "adata = sc.read_h5ad('WagnerScience2018.h5ad')\n",
    "sc.pp.subsample(adata, fraction = 0.08)\n",
    "adata = adata[~adata.obs['ClusterName'].isin(['NaN']),:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "labels = list(adata.obs['TissueName'])\n",
    "labels_id = list(adata.obs['TissueID'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "cats = np.array([cl.split('-',1)[1] for cl in adata.obs['ClusterName']])\n",
    "uni_cats = np.unique(cats)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "tissues = np.array(adata.obs['TissueName'])\n",
    "uni_tissues =  np.unique(np.array([adata.obs[adata.obs['ClusterName'].str.contains(c)]['TissueName'][0] for c in uni_cats]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-15-627c8036739a>:1: ImplicitModificationWarning: Trying to modify attribute `.obs` of view, initializing view as actual.\n",
      "  adata.obs['Cat1'] = tissues\n"
     ]
    }
   ],
   "source": [
    "adata.obs['Cat1'] = tissues \n",
    "adata.obs['Cat2'] = cats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = len(adata.obs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "# true ranking \n",
    "id_2cats = {i:list(adata.obs[['Cat1','Cat2']].iloc[i]) for i in range(n)}\n",
    "pairs = np.array(list(itertools.combinations(list(range(n)), 2)))\n",
    "n_inter =  [len(list(set(id_2cats[pairs[i][0]]) & set(id_2cats[pairs[i][1]]))) for i in range(pairs.shape[0])]\n",
    "\n",
    "upper = np.zeros((n, n))\n",
    "upper[np.triu_indices(n, 1)] = np.max(n_inter) - n_inter\n",
    "true_ranking = upper + upper.T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "filtered out 1381 genes that are detected in less than 3 cells\n"
     ]
    }
   ],
   "source": [
    "sc.pp.filter_cells(adata, min_genes=200)\n",
    "sc.pp.filter_genes(adata, min_cells=3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "normalizing by total count per cell\n",
      "    finished (0:00:00): normalized adata.X and added    'n_counts', counts per cell before normalization (adata.obs)\n"
     ]
    }
   ],
   "source": [
    "sc.pp.normalize_per_cell(adata, counts_per_cell_after=1e4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "extracting highly variable genes\n",
      "    finished (0:00:00)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "filter_result = sc.pp.filter_genes_dispersion(\n",
    "    adata.X, min_mean=0.0125, max_mean=3, min_disp=0.5)\n",
    "sc.pl.filter_genes_dispersion(filter_result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "adata = adata[:, filter_result.gene_subset]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ag16115/anaconda3/lib/python3.8/site-packages/scanpy/preprocessing/_simple.py:373: UserWarning: Received a view of an AnnData. Making a copy.\n",
      "  view_to_actual(adata)\n"
     ]
    }
   ],
   "source": [
    "sc.pp.log1p(adata)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "regressing out n_counts\n",
      "    sparse input is densified and may lead to high memory use\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ag16115/anaconda3/lib/python3.8/site-packages/statsmodels/tsa/base/tsa_model.py:7: FutureWarning: pandas.Int64Index is deprecated and will be removed from pandas in a future version. Use pandas.Index with the appropriate dtype instead.\n",
      "  from pandas import (to_datetime, Int64Index, DatetimeIndex, Period,\n",
      "/home/ag16115/anaconda3/lib/python3.8/site-packages/statsmodels/tsa/base/tsa_model.py:7: FutureWarning: pandas.Float64Index is deprecated and will be removed from pandas in a future version. Use pandas.Index with the appropriate dtype instead.\n",
      "  from pandas import (to_datetime, Int64Index, DatetimeIndex, Period,\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    finished (0:00:37)\n"
     ]
    }
   ],
   "source": [
    "sc.pp.regress_out(adata, 'n_counts')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sc.pp.scale(adata, max_value=10)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PCA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "adata.obs['clusters'] = labels\n",
    "sc._utils.sanitize_anndata(adata)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "list_labels =  np.unique(labels).tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "ordered_cats = list_labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "colors = {\n",
    " 'Endoderm': 'purple',\n",
    " 'Epidermal' : 'dodgerblue',\n",
    " 'Forebrain / Optic' : 'lightsalmon',\n",
    " 'Germline' : 'darkolivegreen',\n",
    " 'Hindbrain / Spinal Cord' : 'firebrick',\n",
    " 'Mesoderm' : 'teal',\n",
    " 'Midbrain' : 'pink',\n",
    " 'NaN' : '#8A8A8A',\n",
    " 'Neural Crest': 'darkorange' ,\n",
    " 'Other' : 'yellow',\n",
    " 'Pluripotent': 'mediumorchid'\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "adata.uns['clusters_colors'] = [colors[clus] for clus in list(adata.obs['clusters'])]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "Y = np.array(adata.to_df())\n",
    "n,p = Y.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5079 5498\n"
     ]
    }
   ],
   "source": [
    "print(n,p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "dim = 29"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "zeta = p**-.5 * pc_scores(Y, dim)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "adata.obsm['PC_scores'] = zeta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f4e9c0bc970>"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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ERGRIAYPiIiIiIiIiEgQgwdEREREREREJIjBAyIiIiIiIiISxOABEREREREREQli8ICIiIiIiIiIBDF4QERERERERESCRHq93v6VRaIrAC60XXWIiIiI2kSYXq/37+hKEBERdVUtCh4QERERERER0V8Phy0QERERERERkSAGD4iIiIiIiIhIEIMHRERERERERCSIwQMiIiIiIiIiEsTgAREREREREREJYvCAiIiIiIiIiAQxeEBEREREREREghg8ICIiIiIiIiJBDB4QERERERERkSAGD4iIiIiIiIhIEIMHRERERERERCSIwQMiIiIiIiIiEsTgAREREREREREJYvCAiIiIiIiIiAQxeEBEREREREREghg8ICIiIiIiIiJB0o6uALXe0aNH5RKJ5DutVjscDAgRERERERGR/fRisfiyTqd7YsiQIZ9ZW4nBg25ALBa/qFAoBkdFRYnFYsYOiIiIiIiIyD46nU5UW1vb89y5c2t37tzpM2HChGRL67Gl2Q3o9fqHQkND3Rk4ICIiIiIiopYQi8Xw8PBAnz595Eql8l9TpkwZanG99q4YOZ9er/eUyWQdXQ0iIiIiIiLqotzd3SGVSt0APDxlyhT/puUMHnQPIpFI1NF1ICIiIiIioi5KLBbjartSDyCgWXm714j+MhISEvDqq686vP3cuXPx8MMPO7FGZI+cnByIRCIUFRU5db8TJ07Em2++6dR9tqeuXn975ObmwsPDA5cvX3Z4H43/bv/K19I111yDr776yin7aqvz6Ijw8HB8/vnnHV2NLmfdunXo379/R1ejy3n44YexcOFCq+VNz2tbXJ8rV67E1KlTnbpPMtfa+0VyzPLlyzFhwoSOrkan4IzPjq5wb9JCIgCSpgsZPCCThIQEyOVyeHh4mP3Lysrq6Kr95Vl6b4RuqDqjHTt24Mknn2z1fkJCQvDLL79YLFOpVHjuuecQHR0NNzc39OzZE3PmzEFeXl6LXsPSl4iz6t9RrN2c9e/fH+vWrQMAhIaGorq6GgEBzQLNnUp7XEvvvvsuYmJi4OnpCR8fHwwfPhx79uyxe99//PEH7r777lbX0V4VFRV46qmnEBUVBYVCgd69e+POO+/EwYMH260OnUVCQgJEIhE2bdpktvzgwYMQiURsxHcC9r5HH3zwAd5+++0OqOGfli5dis2bN3doHZzBeM4PHTpk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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "## plot after applying PCA lhs and after applying PCA then t-SNE on the rhs\n",
    "fig,ax = plt.subplots(1,1,figsize = (10,10))\n",
    "for t in ordered_cats:\n",
    "    idx = np.where(adata.obs['clusters'] == t)[0]\n",
    "    ax.scatter(zeta[idx,0],zeta[idx,1], marker = 'o',edgecolor='black', linewidth=0,s = 80,label = t,c= colors[t]);\n",
    "ax.set_title(f'PCA',fontsize=25)\n",
    "ax.axes.xaxis.set_visible(False)\n",
    "ax.axes.yaxis.set_visible(False)\n",
    "\n",
    "ax.legend(loc='upper center', bbox_to_anchor=(1, -0.02),\n",
    "          fancybox=True, shadow=True, ncol=8)\n",
    "\n",
    "# fig.savefig(f\"planaria.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "AgglomerativeClustering(distance_threshold=0, linkage='average',\n",
       "                        n_clusters=None)"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "idxs = [np.where(np.array(tissues == t))[0] for t in sorted(uni_tissues)]\n",
    "t_zeta = np.array([np.mean(zeta[idx,:],axis = 0) for idx in idxs])\n",
    "ip_t_clust = AgglomerativeClustering(linkage=\"average\", distance_threshold=0, n_clusters = None)\n",
    "ip_t_clust.fit(t_zeta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_dendrogram(ip_t_clust, rescale = True, labels = list(uni_tissues), size = (10,5), orientation='left',truncate_mode=\"level\",color_threshold = 0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# method comparison"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "method_comparison_df = pd.DataFrame()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### inner products"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ip_clust = AgglomerativeClustering(affinity = ip_affinity, linkage = 'average',distance_threshold=0, n_clusters=None)\n",
    "ip_clust.fit(zeta);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ances = {}; desc = {}\n",
    "ip_ranking = np.array([get_ranking(ip_clust,t) for t in range(n)])\n",
    "\n",
    "ip_kt_z = [kendalltau(ip_ranking[i], true_ranking[i]).correlation for i in range(ip_ranking.shape[0])]\n",
    "np.mean(ip_kt_z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ip_clust = AgglomerativeClustering(affinity = ip_affinity, linkage = 'average',distance_threshold=0, n_clusters=None)\n",
    "ip_clust.fit(Y);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ances = {}; desc = {}\n",
    "ip_ranking = np.array([get_ranking(ip_clust,t) for t in range(n)])\n",
    "\n",
    "ip_kt_y = [kendalltau(ip_ranking[i], true_ranking[i]).correlation for i in range(ip_ranking.shape[0])]\n",
    "np.mean(ip_kt_y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### ward"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ward = AgglomerativeClustering(linkage=\"ward\", distance_threshold=0, n_clusters = None)\n",
    "ward.fit(zeta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ances = {}; desc = {}\n",
    "w_ranking = np.array([get_ranking(ward,t) for t in range(n)])\n",
    "\n",
    "w_kt_z = [kendalltau(w_ranking[i], true_ranking[i]).correlation for i in range(w_ranking.shape[0])]\n",
    "np.mean(w_kt_z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ward = AgglomerativeClustering(linkage=\"ward\", distance_threshold=0, n_clusters = None)\n",
    "ward.fit(Y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ances = {}; desc = {}\n",
    "w_ranking = np.array([get_ranking(ward,t) for t in range(n)])\n",
    "\n",
    "w_kt_y = [kendalltau(w_ranking[i], true_ranking[i]).correlation for i in range(w_ranking.shape[0])]\n",
    "np.mean(w_kt_y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### upgma"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "average = AgglomerativeClustering(linkage=\"average\", distance_threshold=0, n_clusters = None)\n",
    "average.fit(zeta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ances = {}; desc  = {}\n",
    "a_ranking = np.array([get_ranking(average,t) for t in range(n)])\n",
    "\n",
    "a_kt_z = [kendalltau(a_ranking[i], true_ranking[i]).correlation for i in range(a_ranking.shape[0])]\n",
    "np.mean(a_kt_z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sem(a_kt_z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "average = AgglomerativeClustering(linkage=\"average\", distance_threshold=0, n_clusters = None)\n",
    "average.fit(Y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ances = {}; desc  = {}\n",
    "a_ranking = np.array([get_ranking(average,t) for t in range(n)])\n",
    "\n",
    "a_kt_y = [kendalltau(a_ranking[i], true_ranking[i]).correlation for i in range(a_ranking.shape[0])]\n",
    "np.mean(a_kt_y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### cosine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "cosine = AgglomerativeClustering(affinity = 'cosine', linkage = 'average', distance_threshold=0, n_clusters = None)\n",
    "cosine.fit(zeta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ances = {}; desc  = {}\n",
    "cs_ranking = np.array([get_ranking(cosine,t) for t in range(n)])\n",
    "\n",
    "cs_kt_z = [kendalltau(cs_ranking[i], true_ranking[i]).correlation for i in range(cs_ranking.shape[0])]\n",
    "np.mean(cs_kt_z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "cosine = AgglomerativeClustering(affinity = 'cosine',linkage = 'average', distance_threshold=0, n_clusters = None)\n",
    "cosine.fit(Y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ances = {}; desc  = {}\n",
    "cs_ranking = np.array([get_ranking(cosine,t) for t in range(n)])\n",
    "\n",
    "cs_kt_y = [kendalltau(cs_ranking[i], true_ranking[i]).correlation for i in range(cs_ranking.shape[0])]\n",
    "np.mean(cs_kt_y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "method_comparison_df['ip_sem'] = [sem(ip_kt_z),sem(ip_kt_y)]\n",
    "\n",
    "method_comparison_df['ward_sem'] = [sem(w_kt_z),sem(w_kt_y)]\n",
    "\n",
    "method_comparison_df['upgma\t_sem'] = [sem(a_kt_z),sem(a_kt_y)]\n",
    "\n",
    "method_comparison_df['cosine_sem'] = [sem(cs_kt_z),sem(cs_kt_y)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "method_comparison_df['ip_z'] = [np.mean(ip_kt_z),sem(ip_kt_z)]\n",
    "method_comparison_df['ip_y'] = [np.mean(ip_kt_y),sem(ip_kt_y)]\n",
    "\n",
    "method_comparison_df['w_z'] = [np.mean(w_kt_z),sem(w_kt_z)]\n",
    "method_comparison_df['w_y'] = [np.mean(w_kt_y),sem(w_kt_y)]\n",
    "\n",
    "method_comparison_df['a_z'] = [np.mean(a_kt_z),sem(a_kt_z)]\n",
    "method_comparison_df['a_y'] = [np.mean(a_kt_y),sem(a_kt_y)]\n",
    "\n",
    "method_comparison_df['cs_z'] = [np.mean(cs_kt_z),sem(cs_kt_z)]\n",
    "method_comparison_df['cs_y'] = [np.mean(cs_kt_y),sem(cs_kt_y)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# method_comparison_df.to_csv('method_comparison.csv', index=False)\n",
    "# method_comparison_df"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### hdbscan"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import hdbscan"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.setrecursionlimit(10000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "hdbscan_ = hdbscan.HDBSCAN()\n",
    "hdbscan_.fit(zeta)\n",
    "\n",
    "hdbscan_.single_linkage_tree_;\n",
    "hdbscan_.children_ = np.array(hdbscan_.single_linkage_tree_.to_pandas()[['left_child','right_child']], dtype=int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ances = {}; desc = {}\n",
    "hdbscan_ranking = np.array([get_ranking(hdbscan_,t) for t in range(n)]) \n",
    "\n",
    "hdbscan_kt_z = [kendalltau(hdbscan_ranking[i], true_ranking[i]).correlation for i in range(hdbscan_ranking.shape[0])]\n",
    "np.mean(hdbscan_kt_z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "hdbscan_ = hdbscan.HDBSCAN()\n",
    "hdbscan_.fit(Y)\n",
    "\n",
    "hdbscan_.single_linkage_tree_;\n",
    "hdbscan_.children_ = np.array(hdbscan_.single_linkage_tree_.to_pandas()[['left_child','right_child']], dtype=int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "ances = {}; desc = {}\n",
    "hdbscan_ranking = np.array([get_ranking(hdbscan_,t) for t in range(n)]) # range(n)\n",
    "\n",
    "hdbscan_kt_y = [kendalltau(hdbscan_ranking[i], true_ranking[i]).correlation for i in range(hdbscan_ranking.shape[0])]\n",
    "np.mean(hdbscan_kt_y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "method_comparison_df['hdbscan_z'] = [np.mean(hdbscan_kt_z),sem(hdbscan_kt_z)]\n",
    "method_comparison_df['hdbscan_y'] = [np.mean(hdbscan_kt_y),sem(hdbscan_kt_y)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "method_comparison_df.to_csv('method_comparison_df.csv', index=False)"
   ]
  }
 ],
 "metadata": {
  "anaconda-cloud": {},
  "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
