{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Graph Basics\n",
    "This notebook shows how define and evaluate kernels on a simple graph. It also shows how to sample from the corresponding Gaussian process prior.\n",
    "\n",
    "We use the **JAX** backend here."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "N2YCQeyY50Xg"
   },
   "outputs": [],
   "source": [
    "# To run this in Google Colab, uncomment the following line\n",
    "# !pip install \"git+https://github.com/GPflow/GeometricKernels.git\"\n",
    "\n",
    "# If you want to use a version of the library from a different git branch,\n",
    "# say, from the \"devel\" branch, uncomment the line below instedad\n",
    "# !pip install \"git+https://github.com/GPflow/GeometricKernels@devel#egg=GeometricKernels\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "NaG9OvVp-Ryf",
    "outputId": "1fbd9363-48ee-4bd0-e214-056a84c64766"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO: Unable to initialize backend 'tpu_driver': NOT_FOUND: Unable to find driver in registry given worker: \n",
      "INFO: Unable to initialize backend 'gpu': NOT_FOUND: Could not find registered platform with name: \"cuda\". Available platform names are: Interpreter Host\n",
      "INFO: Unable to initialize backend 'tpu': INVALID_ARGUMENT: TpuPlatform is not available.\n",
      "WARNING: No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n",
      "INFO: Using numpy backend\n"
     ]
    }
   ],
   "source": [
    "import networkx as nx\n",
    "import jax.numpy as jnp\n",
    "from jax.random import PRNGKey\n",
    "import numpy as onp\n",
    "import geometric_kernels.jax # using jax as backend for geometric_kernels\n",
    "from geometric_kernels.spaces import Graph\n",
    "from geometric_kernels.kernels.geometric_kernels import MaternKarhunenLoeveKernel\n",
    "from geometric_kernels.kernels.feature_maps import deterministic_feature_map_compact\n",
    "from geometric_kernels.sampling import sampler\n",
    "\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Create and Visualize a Graph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "PM1H-As8-KF7"
   },
   "outputs": [],
   "source": [
    "nx_graph = nx.star_graph(6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 516
    },
    "id": "-J-2rY-D-rgY",
    "outputId": "253b3a3d-c0ab-44c8-b507-5be25418681c",
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# illustrate graph\n",
    "nx.draw(nx_graph, node_color = 'black')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The following cell turns the `nx_graph` created above into a GeometricKernels `Graph` space.\n",
    "\n",
    "The `normalize_laplacian` parameter controls whether to use the eigenvectors\n",
    "of the *unnormalized Laplacian* or the *symmetric normalized Laplacian* as\n",
    "features.\n",
    "You may want to try both `normalize_laplacian=False` and `normalize_laplacian=True` for your task.\n",
    "The former is the default."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "id": "YJXKhf4y-tgV"
   },
   "outputs": [],
   "source": [
    "G = Graph(jnp.array(nx.to_numpy_array(nx_graph)), normalize_laplacian=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define a GeometricKernels kernel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "id": "vEZLgfp7ANV4"
   },
   "outputs": [],
   "source": [
    "# create a kernel\n",
    "kernel = MaternKarhunenLoeveKernel(G, G.num_vertices)\n",
    "\n",
    "# initialize kernel with reasonable values\n",
    "params, state = kernel.init_params_and_state()\n",
    "# The following setting of `nu` coresponds to the heat (RBF) kernel\n",
    "# for actual Matérn kernels consider finite values of `nu`\n",
    "params[\"nu\"] = jnp.array([jnp.inf])\n",
    "# Note: the \"reasonable\" range of length scales is different for various graphs\n",
    "params[\"lengthscale\"] = jnp.array([2.])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "_AxR3xsIbzDA"
   },
   "source": [
    "## Define Feature Map and Obtain Two Samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "id": "921dJj4WbyoP"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/vabor112/.local/lib/python3.8/site-packages/jax/_src/numpy/lax_numpy.py:4404: UserWarning: Explicitly requested dtype <class 'jax.numpy.float64'> requested in astype is not available, and will be truncated to dtype float32. To enable more dtypes, set the jax_enable_x64 configuration option or the JAX_ENABLE_X64 shell environment variable. See https://github.com/google/jax#current-gotchas for more.\n",
      "  lax_internal._check_user_dtype_supported(dtype, \"astype\")\n"
     ]
    }
   ],
   "source": [
    "feature_map = deterministic_feature_map_compact(G, kernel)\n",
    "\n",
    "# introduce random state for reproducibility (optional)\n",
    "# `key` is jax's terminology\n",
    "key = PRNGKey(1234)\n",
    "sample_paths = sampler(feature_map, s=2)\n",
    "# new random state is returned along with the samples\n",
    "key, samples = sample_paths(jnp.arange(G.num_vertices)[:, None], params, state, key=key)\n",
    "\n",
    "sample1 = onp.asarray(samples[:, 0])\n",
    "sample2 = onp.asarray(samples[:, 1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "nRzmjQ8rP2Mh"
   },
   "source": [
    "## Visualize Kernel, Prior Variance and Two Samples"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**Important:** the following cell **normalizes** the variances, kernel values and samples, **as if they correspond to a normalized kernel**.\n",
    "\n",
    "We say that the kernel is normalized if the average of k(\\*, \\*), with \\* running over all nodes, equals 1.\n",
    "**By default, the kernel may fail to be normalized.**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 472
    },
    "id": "v9dQIgYYP4ri",
    "outputId": "57c69c80-1fee-4d71-f8e4-083469a6a73a"
   },
   "outputs": [],
   "source": [
    "highlighted_node = 1 # choosing a fixed node for kernel visualization\n",
    "node_ids = jnp.arange(G.num_vertices)[:, None]\n",
    "# Get prior variances k(*, *) for * in nodes:\n",
    "variance = onp.asarray(kernel.K_diag(params, state, node_ids))\n",
    "# Get kernel values k(highlighted_node, *) for * in nodes:\n",
    "values = onp.asarray(kernel.K(params, state, jnp.array([[highlighted_node]]),\n",
    "                              node_ids)).flatten()\n",
    "\n",
    "# Normalize everything\n",
    "mean_variance = jnp.mean(variance)\n",
    "variance /= mean_variance\n",
    "values   /= mean_variance\n",
    "sample1  /= jnp.sqrt(mean_variance)\n",
    "sample2  /= jnp.sqrt(mean_variance)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Here are the actual visualization routines.\n",
    "\n",
    "**Note:** the top right plot shows `k(highlighted_node, *)` where `*` goes through all nodes and `highlighted_node` has red outline. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 921.6x691.2 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "cmap = plt.get_cmap('viridis')\n",
    "\n",
    "# Set the colorbar limits:\n",
    "var_vmin = min(0.0, values.min())\n",
    "var_vmax = max(1.0, variance.max())\n",
    "val_vmin, val_vmax = var_vmin, var_vmax\n",
    "val_smax = max(1., val_vmax, onp.abs(sample1.max()), onp.abs(sample2.max()),\n",
    "               onp.abs(sample1.min()), onp.abs(sample2.min()))\n",
    "val_smin = -val_smax\n",
    "\n",
    "\n",
    "# Red outline for the highlighted_node:\n",
    "edgecolors = [(0, 0, 0, 0)]*G.num_vertices\n",
    "edgecolors[highlighted_node] = (1, 0, 0, 1)\n",
    "\n",
    "# Save graph layout so that graph appears the same in every plot\n",
    "kwargs = {'pos': nx.spring_layout(nx_graph)}\n",
    "\n",
    "\n",
    "fig, ((ax1, ax2), (ax3, ax4)) = plt.subplots(2, 2, figsize=(12.8, 9.6))\n",
    "\n",
    "# Plot variance\n",
    "nx.draw(nx_graph, ax=ax1, cmap=cmap, node_color=variance,\n",
    "        vmin=var_vmin, vmax=var_vmax, **kwargs)\n",
    "sm = plt.cm.ScalarMappable(cmap=cmap,\n",
    "                           norm=plt.Normalize(vmin=var_vmin, vmax=var_vmax))\n",
    "cbar = plt.colorbar(sm, ax=ax1)\n",
    "ax1.set_title('Variance: k(*, *) for * in nodes')\n",
    "\n",
    "# Plot kernel values\n",
    "nx.draw(nx_graph, ax=ax2, cmap=cmap, node_color=values,\n",
    "        vmin=val_vmin, vmax=val_vmax, edgecolors=edgecolors,\n",
    "        linewidths=2.0, **kwargs)\n",
    "sm = plt.cm.ScalarMappable(cmap=cmap,\n",
    "                           norm=plt.Normalize(vmin=val_vmin, vmax=val_vmax))\n",
    "cbar = plt.colorbar(sm, ax=ax2)\n",
    "ax2.set_title('Kernel: k(%d, *) for * in nodes' % highlighted_node)\n",
    "\n",
    "# Plot sample #1 values\n",
    "nx.draw(nx_graph, ax=ax3, cmap=cmap, node_color=sample1,\n",
    "        vmin=val_smin, vmax=val_smax, **kwargs)\n",
    "sm = plt.cm.ScalarMappable(cmap=cmap,\n",
    "                           norm=plt.Normalize(vmin=val_smin, vmax=val_smax))\n",
    "cbar = plt.colorbar(sm, ax=ax3)\n",
    "ax3.set_title('Sample #1: f(*) for * in nodes where f ~ GP(0, k)')\n",
    "\n",
    "# Plot sample #2 values\n",
    "nx.draw(nx_graph, ax=ax4, cmap=cmap, node_color=sample2,\n",
    "        vmin=val_smin, vmax=val_smax, **kwargs)\n",
    "sm = plt.cm.ScalarMappable(cmap=cmap,\n",
    "                           norm=plt.Normalize(vmin=val_smin, vmax=val_smax))\n",
    "cbar = plt.colorbar(sm, ax=ax4)\n",
    "ax4.set_title('Sample #2: f(*) for * in nodes where f ~ GP(0, k)')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## A Note on Prior Variance"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Note that the **variance changes from node to node** on this graph.\n",
    "\n",
    "For example, for the **unnormalized Laplacian**, the variance is related to the *return time of a random walk*: how many steps, on average, does it take a particle\n",
    "randomly walking over the graph and starting in node x to return back to node x.\n",
    "For the center node, the return time is always equal to 2.\n",
    "For other nodes, it is always higher.\n",
    "Hence the variance in the center is *lower* than in the other nodes.\n",
    "\n",
    "For the **symmetric normalized Laplacian** the sitation is different.\n",
    "\n",
    "This argument is inspired by [Borovitskiy et al. (2021)](https://arxiv.org/pdf/2010.15538.pdf)\n",
    "See this [Jupyter notebook](https://github.com/spbu-math-cs/Graph-Gaussian-Processes/blob/main/examples/graph_variance.ipynb) for more examples of how variance differs for different graphs."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Variance in the center node is 0.60, variance in the side nodes is 1.07. The average variance is 1.00.\n"
     ]
    }
   ],
   "source": [
    "print('Variance in the center node is %0.2f,' % variance[0],\n",
    "      'variance in the side nodes is %0.2f.' % variance[1],\n",
    "      'The average variance is %0.2f.' % onp.mean(variance))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "provenance": []
  },
  "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
