{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy as sp\n",
    "import scipy.sparse\n",
    "import scipy.stats as st\n",
    "\n",
    "import pandas as pd\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import f1_score, roc_auc_score\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Utility functions:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def edge_idcs_to_incidence(edge_idcs, n=None, signed=False):\n",
    "    \"\"\"\n",
    "    Convert a sequence of edge indices to an m x n incidence matrix\n",
    "    \n",
    "    :edge_idcs: 2xm index matrix of integers, gives the indices of the node endpoints of edges\n",
    "    :n: number of nodes\n",
    "    :signed: whether the incidence matrix should be signed\n",
    "    \"\"\"\n",
    "    if n is None:\n",
    "        n = edge_idcs.max() + 1\n",
    "    m = edge_idcs.shape[0]\n",
    "    incid = sp.sparse.lil_array((m,n))\n",
    "    if signed:\n",
    "        incid[np.arange(m),edge_idcs[:,0]] = -1\n",
    "    else:\n",
    "        incid[np.arange(m),edge_idcs[:,0]] = +1        \n",
    "    incid[np.arange(m),edge_idcs[:,1]] = +1\n",
    "    return incid\n",
    "\n",
    "# Given some values, calculate the gap between the mean and upper/lower bound of the 95% confidence interval:\n",
    "conf_int_95 = lambda a : st.t.interval(0.95, len(a)-1, loc=np.mean(a), scale=st.sem(a))[1] - np.mean(a)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Function for creating the TDLG:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_tdlg(edge_idcs, times, sigma_t):\n",
    "    \"\"\"\n",
    "    Return the TDLG adjacency matrix given edge indices and edge times\n",
    "    \n",
    "    :sigma_t: decay rate of connections between interactions as time difference grows\n",
    "    \"\"\"\n",
    "    \n",
    "    incid = edge_idcs_to_incidence(edge_idcs, signed=False)\n",
    "    \n",
    "    adj_line = incid@incid.T\n",
    "    adj_line_tdecay = sp.sparse.coo_array(adj_line)\n",
    "    adj_line_tdecay.data *= np.exp(-((times[adj_line_tdecay.row]-times[adj_line_tdecay.col]) / (2*sigma_t))**2)\n",
    "    adj_line_tdecay = sp.sparse.csr_array(adj_line_tdecay)\n",
    "\n",
    "    return adj_line_tdecay.astype(float)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Creating and plotting a Temporal SBM:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def two_comm_sbm_explicit(n, exp_deg, alpha):\n",
    "    \"\"\"\n",
    "    Create a sampled SBM with given n (num nodes), expected degree, and alpha (homophily ratio)\n",
    "    \"\"\"\n",
    "    u_idcs, v_idcs = np.arange(0,n//2), np.arange(n//2,n)\n",
    "    num_homoph = int((alpha*exp_deg*n)//4)\n",
    "    num_heteroph = int(((1-alpha)*exp_deg*n)//2)\n",
    "    uu = np.hstack((np.random.choice(u_idcs, size=num_homoph)[:,None],\n",
    "                     np.random.choice(u_idcs, size=num_homoph)[:,None]))\n",
    "    uv = np.hstack((np.random.choice(u_idcs, size=num_heteroph)[:,None],\n",
    "                     np.random.choice(v_idcs, size=num_heteroph)[:,None]))\n",
    "    vv = np.hstack((np.random.choice(v_idcs, size=num_homoph)[:,None],\n",
    "                     np.random.choice(v_idcs, size=num_homoph)[:,None]))\n",
    "    adj = np.zeros((n,n))\n",
    "    adj[uu[:,0],uu[:,1]] = 1\n",
    "    adj[uv[:,0],uv[:,1]] = 1\n",
    "    adj[vv[:,0],vv[:,1]] = 1\n",
    "    adj = np.maximum(adj, adj.T)\n",
    "    edge_labels = np.concatenate((0*np.ones(num_homoph), 1*np.ones(num_heteroph), 2*np.ones(num_homoph))).astype(int)\n",
    "    return np.vstack((uu,uv,vv)), adj, edge_labels\n",
    "\n",
    "def get_tsbm_explicit(n, exp_deg, alpha1, alpha2, mu1, mu2, sig1, sig2):\n",
    "    \"\"\"\n",
    "    Create a sampled TSBM with given n (num nodes), expected degree, alpha1/2 (homophily ratios), and time distribs\n",
    "    \"\"\"\n",
    "    \n",
    "    edge_idcs_1, sbm1, edge_labels1 = two_comm_sbm_explicit(n, exp_deg, alpha1)\n",
    "    edge_idcs_2, sbm2, edge_labels2 = two_comm_sbm_explicit(n, exp_deg, alpha2)\n",
    "    \n",
    "    node_labels = np.arange(n) < n//2\n",
    "    m1, m2 = edge_idcs_1.shape[0], edge_idcs_2.shape[0]\n",
    "    t1, t2 = np.random.normal(mu1,sig1,size=m1), np.random.normal(mu2,sig2,size=m2)\n",
    "\n",
    "    edge_idcs = np.vstack((edge_idcs_1,edge_idcs_2))\n",
    "    times = np.concatenate((t1,t2))\n",
    "    edge_labels = np.concatenate((edge_labels1, edge_labels2+3))\n",
    "    \n",
    "    return edge_idcs, times, node_labels, edge_labels, sbm1, sbm2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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sxrpQWCWKOq2024k3BEgTzCzi4GjgJc45+6puj1ZZbl17vlEH6y29v39lwPHAR8HtgcuBXYCvg8c6Zzb3LHPm4gGQNcDc8CVwHsD2zEFfISusG+pHb1O9Teor1Fd+ioY3HM8SPQaNcOgvk516a8G9fwOGr1OzaDXqSGccw8AD/hs24pk+g5wM3C8c26uzLY1jXNu2sxuJorCvQq23gZ2BNF3lMSw6H7bi4DXA8ucc3dV3KRczDlXdRtEREREREREaqt1kWk18GvgLUSROwA45xSt02JmbySaKHkH8EPgZOAvgKc757pzN0mLmV0CHAv8CfDLjlUbnXOPV9Oq7HShSURERERERCRB63Hzq3qtc84p+3sHM3s38AFgCdGDK97rnFPOwARmFndh5njn3GX9bEsRdKFJREREREREREQKUfRT50REREREREREZEjpQpOIiIiIiIiIiBRCF5pERERERERERKQQutAkIiIiIiIiIiKF0IUmEREREREREREphC40iYiIiIiIiIhIIXShSURERERERERECqELTSIiIiIiIiIiUghdaBIRERERERERkULoQpOIiIiIiIiIiBRCF5pERERERERERKQQ/x/F7WDRAffzkQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1200x300 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "n = 100\n",
    "exp_deg = 40\n",
    "alpha1, alpha2 = 0.9, 0.1\n",
    "mu1, mu2 = -1, +1\n",
    "sig1, sig2 = 1/2, 1/2\n",
    "edge_idcs, times, node_labels, edge_labels, sbm1, sbm2 = get_tsbm_explicit(n, exp_deg, alpha1, alpha2, mu1, mu2, sig1, sig2)\n",
    "\n",
    "fig, axes = plt.subplots(nrows=1, ncols=4, dpi=100, figsize=(12,3))\n",
    "axes[0].matshow(sbm1, cmap='Blues')\n",
    "axes[0].set_title('Early')\n",
    "axes[1].matshow(sbm2, cmap='Blues')\n",
    "axes[1].set_title('Late')\n",
    "axes[2].matshow(np.maximum(sbm1,sbm2), cmap='Blues')\n",
    "axes[2].set_title('Union')\n",
    "for ax in axes[:3]:\n",
    "    ax.set_xticks([0,50,100])\n",
    "    ax.set_yticks([0,50,100])\n",
    "node_colors = np.array(['indianred', 'steelblue'])\n",
    "axes[3].hist(times[edge_labels<3], alpha=0.7, bins=20, color=node_colors[0], label='Early')\n",
    "axes[3].hist(times[edge_labels>=3], alpha=0.7, bins=20, color=node_colors[1], label='Late')\n",
    "axes[3].axvline(-1, color='red', linestyle='--')\n",
    "axes[3].axvline(+1, color='blue', linestyle='--')\n",
    "axes[3].legend(loc='lower right')\n",
    "axes[3].set_xlim(-3,3)\n",
    "axes[3].set_title('Time Distribution')\n",
    "axes[3].grid(axis='y')\n",
    "plt.tight_layout()\n",
    "pos = axes[3].get_position()\n",
    "px, py, w, h = pos.x0, pos.y0, pos.width, pos.height\n",
    "axes[3].set_position([px,py+0.045,w,h])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Create and plot the time-decayed line graph of this TSBM:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 600x300 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "adj_line = get_tdlg(edge_idcs, times, sigma_t=np.inf).todense()\n",
    "adj_tdlg = get_tdlg(edge_idcs, times, sigma_t=1/2).todense()\n",
    "\n",
    "fig, axes = plt.subplots(nrows=1, ncols=2, dpi=100, figsize=(6,3))\n",
    "axes[0].matshow(adj_line, cmap='Blues', vmin=0,vmax=1)\n",
    "im = axes[1].matshow(adj_tdlg, cmap='Blues', vmin=0,vmax=1)\n",
    "axes[0].set_title('Raw Line Graph')\n",
    "axes[1].set_title('Time Decayed')\n",
    "for ax in axes:\n",
    "    ax.set_xticks([0,2000,4000])\n",
    "    ax.set_yticks([0,2000,4000])\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Create and plot the (spectral) edge embeddings and mean-edge node embedddings:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 600x300 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "evals, evecs = scipy.sparse.linalg.eigsh(adj_tdlg, k=3)\n",
    "edge_embed = (np.sqrt(np.abs(evals))[None,:] * evecs)[:,[1,0]] # scale evecs by evals and choose 2nd and 3rd largest evecs\n",
    "norm_rows = lambda M : M / M.sum(axis=1)[:,None]\n",
    "incid = edge_idcs_to_incidence(edge_idcs, n)\n",
    "node_embed = norm_rows(incid.T) @ edge_embed # take the mean of embeddings of all edges of the node\n",
    "\n",
    "fig, axes = plt.subplots(nrows=1, ncols=2, dpi=100, figsize=(6,3))\n",
    "colors = np.array(plt.style.library['tableau-colorblind10']['axes.prop_cycle'].by_key()['color'])\n",
    "colors = np.delete(colors,[2])\n",
    "edge_colors = colors[[0,1,2,3,5,4]]\n",
    "\n",
    "axes[0].scatter(edge_embed[:,0], edge_embed[:,1], s=0.5, \n",
    "                color=edge_colors[edge_labels.astype(int)], alpha=0.5)\n",
    "axes[0].set_title('Edge Embedding')\n",
    "axes[1].scatter(node_embed[:,0], node_embed[:,1], s=5, color=node_colors[node_labels.astype(int)])\n",
    "axes[1].set_title('Node Embedding')\n",
    "plt.tight_layout()\n",
    "for ax in axes:\n",
    "    ax.xaxis.set_major_locator(plt.MaxNLocator(3))\n",
    "    ax.yaxis.set_major_locator(plt.MaxNLocator(4))\n",
    "    ax.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Experiments on real-world graphs:"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Loading networks:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_dataset(name):\n",
    "    if name == 'bitcoinalpha':\n",
    "        df = pd.read_csv(\"./data/soc-sign-bitcoinalpha.csv\", header=None, names=['Source','Target','Rating','Time'])\n",
    "        edge_labels = np.array(np.sign(df['Rating'])) # reduced from -10,-9,...,+9,+10\n",
    "        times = np.array(df['Time'])\n",
    "    elif name == 'bitcoinotc':\n",
    "        df = pd.read_csv(\"./data/soc-sign-bitcoinotc.csv\", header=None, names=['Source','Target','Rating','Time'])\n",
    "        edge_labels = np.array(np.sign(df['Rating'])) # reduced from -10,-9,...,+9,+10\n",
    "        times = np.array(df['Time'])\n",
    "    elif name == 'escorts':\n",
    "        df = pd.read_csv(\"./data/escorts.edges\", skiprows=6, header=None, sep=' ', \n",
    "                 names=['Source','Target','Rating','Time'])\n",
    "        edge_labels = np.array(df['Rating'])\n",
    "        times = np.array(df['Time'])\n",
    "    elif name == 'wikielect':\n",
    "        df = pd.read_csv(\"./data/soc-wiki-elec.edges\", skiprows=0, header=None, sep=' ', \n",
    "                 names=['Source','Target','Rating', 'Time'])\n",
    "        edge_labels = np.array(df['Rating'])\n",
    "        times = np.array(df['Time'])\n",
    "    else:\n",
    "        print(\"No such dataset.\")\n",
    "        return None, None, None\n",
    "\n",
    "    node_ids = np.unique(np.concatenate((df['Source'], df['Target'])))\n",
    "    n = len(node_ids)\n",
    "    node_id_to_idx = dict(zip(node_ids, np.arange(n)))\n",
    "\n",
    "    edge_idcs = np.hstack((np.array([node_id_to_idx[id1] for id1 in df['Source']])[:,None],\n",
    "                           np.array([node_id_to_idx[id2] for id2 in df['Target']])[:,None]))    \n",
    "    edge_labels = np.where(edge_labels==+1, 1, 0)\n",
    "    return edge_idcs, times, edge_labels"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Edge classification, AUCs and 95\\% confidence intervals:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset 'bitcoinalpha' with 3783 nodes and 24186 edges:\t0.9245 +/- 0.0087\n",
      "Dataset 'bitcoinotc' with 5881 nodes and 35592 edges:\t0.9358 +/- 0.0067\n",
      "Dataset 'escorts' with 10106 nodes and 50632 edges:\t0.7574 +/- 0.0028\n",
      "Dataset 'wikielect' with 7118 nodes and 107071 edges:\t0.9077 +/- 0.0018\n"
     ]
    }
   ],
   "source": [
    "num_trials = 5\n",
    "test_size = 0.3\n",
    "\n",
    "for dset in ['bitcoinalpha', 'bitcoinotc', 'escorts', 'wikielect']:\n",
    "    edge_idcs, times, edge_labels = load_dataset(dset)\n",
    "    m = len(edge_labels)\n",
    "    \n",
    "    print(f\"Dataset '{dset}' with {edge_idcs.max()+1} nodes and {len(times)} edges:\", end='\\t')\n",
    "    adj_tdlg = get_tdlg(edge_idcs, times, sigma_t=(1e-1 * times.std()))\n",
    "    f1s = np.zeros(num_trials)\n",
    "    for i in range(num_trials):\n",
    "        train_idcs, test_idcs = train_test_split(np.arange(m), test_size=test_size)\n",
    "        clf = LogisticRegression(max_iter=1e3, class_weight=\"balanced\").fit(adj_tdlg[train_idcs,:], edge_labels[train_idcs])\n",
    "        f1s[i] = roc_auc_score(edge_labels[test_idcs], clf.predict_proba(adj_tdlg[test_idcs,:])[:,1])\n",
    "    print(f\"{f1s.mean():0.4f} +/- {conf_int_95(f1s):0.4f}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Link prediction, AUCs and 95\\% confidence intervals:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset 'bitcoinalpha' with 3783 nodes and 24186 edges:\tExtrap:\t0.9596 +/- 0.0386\tInterp:\t0.9298 +/- 0.0032\n",
      "Dataset 'bitcoinotc' with 5881 nodes and 35592 edges:\tExtrap:\t0.8123 +/- 0.0307\tInterp:\t0.9342 +/- 0.0027\n",
      "Dataset 'escorts' with 10106 nodes and 50632 edges:\tExtrap:\t0.6506 +/- 0.0173\tInterp:\t0.7924 +/- 0.0034\n",
      "Dataset 'wikielect' with 7118 nodes and 107071 edges:\tExtrap:\t0.7185 +/- 0.0188\tInterp:\t0.9842 +/- 0.0002\n"
     ]
    }
   ],
   "source": [
    "num_trials = 3\n",
    "test_size = 0.3\n",
    "num_periods = 20\n",
    "\n",
    "for dset in ['bitcoinalpha', 'bitcoinotc', 'escorts', 'wikielect']:\n",
    "    pos_edge_idcs, pos_times, _ = load_dataset(dset)\n",
    "    m = len(pos_times)    \n",
    "    time_period = (pos_times.max()-pos_times.min()) / num_periods # time range, divided by number of time periods\n",
    "    \n",
    "    print(f\"Dataset '{dset}' with {pos_edge_idcs.max()+1} nodes and {len(pos_times)} edges:\", end='\\t')\n",
    "    extrap_aucs, interp_aucs = np.zeros(num_trials), np.zeros(num_trials)\n",
    "    for i in range(num_trials):\n",
    "        np.random.seed(i)\n",
    "        neg_edge_idcs = np.hstack((np.random.permutation(pos_edge_idcs[:,0])[:,None], \n",
    "                                   np.random.permutation(pos_edge_idcs[:,1])[:,None])) # permute \n",
    "        neg_times = np.random.permutation(pos_times)\n",
    "        train_idcs, test_idcs = train_test_split(np.arange(2*m), test_size=test_size)\n",
    "        \n",
    "        all_edge_idcs = np.vstack((pos_edge_idcs, neg_edge_idcs))\n",
    "        all_times = np.concatenate((pos_times, neg_times))\n",
    "        all_edge_labels = np.zeros(2*m, dtype=bool)\n",
    "        all_edge_labels[:m] = 1 # first m edges are positive/true edges, rest are negative\n",
    "\n",
    "        early_mask, late_mask = np.zeros(2*m, dtype=bool), np.zeros(2*m, dtype=bool) # mask to separate edges in last time period from others\n",
    "        late_mask[np.clip((all_times - all_times.min()) // time_period, 0, num_periods-1) == num_periods-1] = 1\n",
    "        early_mask = ~late_mask\n",
    "\n",
    "        train_mask, test_mask = np.zeros(2*m, dtype=bool), np.zeros(2*m, dtype=bool)\n",
    "        train_mask[train_idcs] = 1\n",
    "        test_mask[test_idcs] = 1\n",
    "        \n",
    "        train_early = train_mask & early_mask\n",
    "        adj_tdlg = get_tdlg(all_edge_idcs, all_times, sigma_t=(1e-1 * all_times[train_early].std()))\n",
    "        adj_tdlg = adj_tdlg[:,train_early] # can only use proximity to training data as training features\n",
    "        \n",
    "        clf = LogisticRegression(max_iter=1e3, class_weight=\"balanced\").fit(adj_tdlg[train_early,:],\n",
    "                                                                            all_edge_labels[train_early])\n",
    "        extrap_aucs[i] = roc_auc_score(all_edge_labels[late_mask], \n",
    "                                       clf.predict_proba(adj_tdlg[late_mask,:])[:,1]) # predict over late edges\n",
    "        interp_aucs[i] = roc_auc_score(all_edge_labels[test_mask & early_mask], \n",
    "                                       clf.predict_proba(adj_tdlg[test_mask & early_mask,:])[:,1]) # predict over early test edges\n",
    "    print(f\"Extrap:\\t{extrap_aucs.mean():0.4f} +/- {conf_int_95(extrap_aucs):0.4f}\\tInterp:\\t{interp_aucs.mean():0.4f} +/- {conf_int_95(interp_aucs):0.4f}\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
