{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "kmXixGyeAhC2"
   },
   "source": [
    "## Import packages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Mx3QDxHOAhC6",
    "outputId": "8d0249ed-e8f0-462b-94bd-2a72f756c277"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from -r requirements.txt (line 1)) (1.19.5)\n",
      "Requirement already satisfied: torch in /usr/local/lib/python3.7/dist-packages (from -r requirements.txt (line 2)) (1.9.0+cu102)\n",
      "Requirement already satisfied: networkx in /usr/local/lib/python3.7/dist-packages (from -r requirements.txt (line 3)) (2.6.3)\n",
      "Requirement already satisfied: sklearn in /usr/local/lib/python3.7/dist-packages (from -r requirements.txt (line 4)) (0.0)\n",
      "Requirement already satisfied: scipy in /usr/local/lib/python3.7/dist-packages (from -r requirements.txt (line 5)) (1.4.1)\n",
      "Requirement already satisfied: cvxpy in /usr/local/lib/python3.7/dist-packages (from -r requirements.txt (line 6)) (1.0.31)\n",
      "Collecting wwl\n",
      "  Using cached wwl-0.1.2-py3-none-any.whl (8.2 kB)\n",
      "Collecting pyunlocbox\n",
      "  Using cached pyunlocbox-0.5.2-py2.py3-none-any.whl (41 kB)\n",
      "Collecting graspologic\n",
      "  Downloading graspologic-0.3.0.tar.gz (5.1 MB)\n",
      "\u001b[K     |████████████████████████████████| 5.1 MB 5.4 MB/s \n",
      "\u001b[?25h  Installing build dependencies ... \u001b[?25l\u001b[?25hdone\n",
      "  Getting requirements to build wheel ... \u001b[?25l\u001b[?25hdone\n",
      "  Installing backend dependencies ... \u001b[?25l\u001b[?25hdone\n",
      "    Preparing wheel metadata ... \u001b[?25l\u001b[?25hdone\n",
      "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.7/dist-packages (from torch->-r requirements.txt (line 2)) (3.7.4.3)\n",
      "Requirement already satisfied: scikit-learn in /usr/local/lib/python3.7/dist-packages (from sklearn->-r requirements.txt (line 4)) (0.22.2.post1)\n",
      "Requirement already satisfied: osqp>=0.4.1 in /usr/local/lib/python3.7/dist-packages (from cvxpy->-r requirements.txt (line 6)) (0.6.2.post0)\n",
      "Requirement already satisfied: ecos>=2 in /usr/local/lib/python3.7/dist-packages (from cvxpy->-r requirements.txt (line 6)) (2.0.7.post1)\n",
      "Requirement already satisfied: multiprocess in /usr/local/lib/python3.7/dist-packages (from cvxpy->-r requirements.txt (line 6)) (0.70.12.2)\n",
      "Requirement already satisfied: scs>=1.1.3 in /usr/local/lib/python3.7/dist-packages (from cvxpy->-r requirements.txt (line 6)) (2.1.4)\n",
      "Requirement already satisfied: qdldl in /usr/local/lib/python3.7/dist-packages (from osqp>=0.4.1->cvxpy->-r requirements.txt (line 6)) (0.1.5.post0)\n",
      "Collecting POT\n",
      "  Downloading POT-0.7.0-cp37-cp37m-manylinux2010_x86_64.whl (430 kB)\n",
      "\u001b[K     |████████████████████████████████| 430 kB 37.6 MB/s \n",
      "\u001b[?25hCollecting python-igraph\n",
      "  Downloading python_igraph-0.9.6-cp37-cp37m-manylinux2010_x86_64.whl (3.2 MB)\n",
      "\u001b[K     |████████████████████████████████| 3.2 MB 29.8 MB/s \n",
      "\u001b[?25hRequirement already satisfied: Cython in /usr/local/lib/python3.7/dist-packages (from wwl->-r requirements.txt (line 7)) (0.29.24)\n",
      "Collecting graspologic-native>=1.0.0\n",
      "  Downloading graspologic_native-1.0.0-cp37-cp37m-manylinux_2_24_x86_64.whl (926 kB)\n",
      "\u001b[K     |████████████████████████████████| 926 kB 36.1 MB/s \n",
      "\u001b[?25hCollecting hyppo>=0.2.0\n",
      "  Downloading hyppo-0.2.1.tar.gz (60 kB)\n",
      "\u001b[K     |████████████████████████████████| 60 kB 7.0 MB/s \n",
      "\u001b[?25hCollecting gensim<=3.9.0,>=3.8.0\n",
      "  Downloading gensim-3.8.3-cp37-cp37m-manylinux1_x86_64.whl (24.2 MB)\n",
      "\u001b[K     |████████████████████████████████| 24.2 MB 2.0 MB/s \n",
      "\u001b[?25hCollecting umap-learn>=0.4.6\n",
      "  Downloading umap-learn-0.5.1.tar.gz (80 kB)\n",
      "\u001b[K     |████████████████████████████████| 80 kB 9.1 MB/s \n",
      "\u001b[?25hRequirement already satisfied: matplotlib<=3.3.0,>=3.0.0 in /usr/local/lib/python3.7/dist-packages (from graspologic->-r requirements.txt (line 9)) (3.2.2)\n",
      "Collecting anytree>=2.8.0\n",
      "  Downloading anytree-2.8.0-py2.py3-none-any.whl (41 kB)\n",
      "\u001b[K     |████████████████████████████████| 41 kB 530 kB/s \n",
      "\u001b[?25hRequirement already satisfied: seaborn>=0.11.0 in /usr/local/lib/python3.7/dist-packages (from graspologic->-r requirements.txt (line 9)) (0.11.2)\n",
      "Collecting beartype>=0.7.1\n",
      "  Downloading beartype-0.8.1-py3-none-any.whl (457 kB)\n",
      "\u001b[K     |████████████████████████████████| 457 kB 34.3 MB/s \n",
      "\u001b[?25hRequirement already satisfied: joblib>=0.17.0 in /usr/local/lib/python3.7/dist-packages (from graspologic->-r requirements.txt (line 9)) (1.0.1)\n",
      "Requirement already satisfied: six>=1.9.0 in /usr/local/lib/python3.7/dist-packages (from anytree>=2.8.0->graspologic->-r requirements.txt (line 9)) (1.15.0)\n",
      "Requirement already satisfied: smart-open>=1.8.1 in /usr/local/lib/python3.7/dist-packages (from gensim<=3.9.0,>=3.8.0->graspologic->-r requirements.txt (line 9)) (5.2.1)\n",
      "Requirement already satisfied: numba>=0.46 in /usr/local/lib/python3.7/dist-packages (from hyppo>=0.2.0->graspologic->-r requirements.txt (line 9)) (0.51.2)\n",
      "Requirement already satisfied: python-dateutil>=2.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib<=3.3.0,>=3.0.0->graspologic->-r requirements.txt (line 9)) (2.8.2)\n",
      "Requirement already satisfied: pyparsing!=2.0.4,!=2.1.2,!=2.1.6,>=2.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib<=3.3.0,>=3.0.0->graspologic->-r requirements.txt (line 9)) (2.4.7)\n",
      "Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib<=3.3.0,>=3.0.0->graspologic->-r requirements.txt (line 9)) (1.3.2)\n",
      "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.7/dist-packages (from matplotlib<=3.3.0,>=3.0.0->graspologic->-r requirements.txt (line 9)) (0.10.0)\n",
      "Requirement already satisfied: llvmlite<0.35,>=0.34.0.dev0 in /usr/local/lib/python3.7/dist-packages (from numba>=0.46->hyppo>=0.2.0->graspologic->-r requirements.txt (line 9)) (0.34.0)\n",
      "Requirement already satisfied: setuptools in /usr/local/lib/python3.7/dist-packages (from numba>=0.46->hyppo>=0.2.0->graspologic->-r requirements.txt (line 9)) (57.4.0)\n",
      "Requirement already satisfied: pandas>=0.23 in /usr/local/lib/python3.7/dist-packages (from seaborn>=0.11.0->graspologic->-r requirements.txt (line 9)) (1.1.5)\n",
      "Requirement already satisfied: pytz>=2017.2 in /usr/local/lib/python3.7/dist-packages (from pandas>=0.23->seaborn>=0.11.0->graspologic->-r requirements.txt (line 9)) (2018.9)\n",
      "Collecting pynndescent>=0.5\n",
      "  Downloading pynndescent-0.5.4.tar.gz (1.1 MB)\n",
      "\u001b[K     |████████████████████████████████| 1.1 MB 41.7 MB/s \n",
      "\u001b[?25hRequirement already satisfied: dill>=0.3.4 in /usr/local/lib/python3.7/dist-packages (from multiprocess->cvxpy->-r requirements.txt (line 6)) (0.3.4)\n",
      "Collecting texttable>=1.6.2\n",
      "  Downloading texttable-1.6.4-py2.py3-none-any.whl (10 kB)\n",
      "Building wheels for collected packages: graspologic, hyppo, umap-learn, pynndescent\n",
      "  Building wheel for graspologic (PEP 517) ... \u001b[?25l\u001b[?25hdone\n",
      "  Created wheel for graspologic: filename=graspologic-0.3.0-py3-none-any.whl size=5176356 sha256=27d1cc7f9ec9a4be676f29a0bf08b5849d4c7fba0fb555fbffce2246e2d4afd0\n",
      "  Stored in directory: /root/.cache/pip/wheels/e7/04/3b/22feb211ff2c25b05c0d6d6e273c256016bf87451c3aaa106d\n",
      "  Building wheel for hyppo (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
      "  Created wheel for hyppo: filename=hyppo-0.2.1-py3-none-any.whl size=98833 sha256=72ba72c6580ac55438dec77c23b3d4c86309748d1c1a3f0171ee6aac403f3e65\n",
      "  Stored in directory: /root/.cache/pip/wheels/28/6c/e6/8fd8a0d9d61fd4f2766b0663adeb0313d1adc3d459f2c98aca\n",
      "  Building wheel for umap-learn (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
      "  Created wheel for umap-learn: filename=umap_learn-0.5.1-py3-none-any.whl size=76564 sha256=1a7b2b7872437b0c0b1b3ed0547c46880827d4b5159e4aa620a563b7abf45ca0\n",
      "  Stored in directory: /root/.cache/pip/wheels/01/e7/bb/347dc0e510803d7116a13d592b10cc68262da56a8eec4dd72f\n",
      "  Building wheel for pynndescent (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
      "  Created wheel for pynndescent: filename=pynndescent-0.5.4-py3-none-any.whl size=52373 sha256=6468133c7551e7a12f84e7e237a2182450a6be02a3e0ea8636842e043074ba70\n",
      "  Stored in directory: /root/.cache/pip/wheels/d0/5b/62/3401692ddad12324249c774c4b15ccb046946021e2b581c043\n",
      "Successfully built graspologic hyppo umap-learn pynndescent\n",
      "Installing collected packages: texttable, pynndescent, umap-learn, python-igraph, POT, hyppo, graspologic-native, gensim, beartype, anytree, wwl, pyunlocbox, graspologic\n",
      "  Attempting uninstall: gensim\n",
      "    Found existing installation: gensim 3.6.0\n",
      "    Uninstalling gensim-3.6.0:\n",
      "      Successfully uninstalled gensim-3.6.0\n",
      "Successfully installed POT-0.7.0 anytree-2.8.0 beartype-0.8.1 gensim-3.8.3 graspologic-0.3.0 graspologic-native-1.0.0 hyppo-0.2.1 pynndescent-0.5.4 python-igraph-0.9.6 pyunlocbox-0.5.2 texttable-1.6.4 umap-learn-0.5.1 wwl-0.1.2\n"
     ]
    }
   ],
   "source": [
    "!pip install -r requirements.txt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "id": "XdT8mhK9AhC8"
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "from utils import load_graph, download_datasets, data_simulation\n",
    "\n",
    "from NCLM import simulate_nclm\n",
    "from DSC_SSDP import simulate_histogram\n",
    "from WWLGK import simulate_wwlgk\n",
    "from NCMMD import simulate_ncmmd\n",
    "from GNTK import simulate_gntk\n",
    "from NCGMM import simulate_ncgmm\n",
    "\n",
    "from two_sample_test import bootstraping"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "gMPI2qpMAhC8"
   },
   "source": [
    "## Download and load real datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "r9EXslqbAhC9"
   },
   "outputs": [],
   "source": [
    "download_datasets()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 350
    },
    "id": "FuuzCGrsAhC9",
    "outputId": "04124be5-60b1-4617-9098-1cd481aaa36d"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading graph dataset: KKI\n",
      "Loaded and the total number of graphs are  7\n",
      "max num of nodes is  90\n",
      "total graphs  7\n",
      "histogram of number of nodes in  KKI\n"
     ]
    },
    {
     "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": [
    "kki = load_graph(min_num_nodes=60, name='KKI')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 350
    },
    "id": "6CdkpTZRAhC9",
    "outputId": "5af2eb59-e8f5-4e80-ec0f-e18e3d0d0aea"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading graph dataset: PROTEINS\n",
      "Loaded and the total number of graphs are  7\n",
      "max num of nodes is  620\n",
      "total graphs  7\n",
      "histogram of number of nodes in  PROTEINS\n"
     ]
    },
    {
     "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": [
    "proteins = load_graph(min_num_nodes=250, name='PROTEINS')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 350
    },
    "id": "lFUT13K9AhC-",
    "outputId": "fd9a296f-48c0-4a36-c40e-78ed28de2d7f"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading graph dataset: Peking_1\n",
      "Loaded and the total number of graphs are  7\n",
      "max num of nodes is  134\n",
      "total graphs  7\n",
      "histogram of number of nodes in  Peking_1\n"
     ]
    },
    {
     "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": [
    "peking = load_graph(min_num_nodes=80, name='Peking_1')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 350
    },
    "id": "JWWKtXD9AhC-",
    "outputId": "0f2a14ea-1735-4efe-df19-a7652c3ffbf1"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading graph dataset: OHSU\n",
      "Loaded and the total number of graphs are  9\n",
      "max num of nodes is  171\n",
      "total graphs  9\n",
      "histogram of number of nodes in  OHSU\n"
     ]
    },
    {
     "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": [
    "ohsu = load_graph(min_num_nodes=140, name='OHSU')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Na_wCmIYAhC-",
    "outputId": "4cdd43b6-0d93-4839-dbe8-eceb30c07853"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 1., 1., 1., 1., 1., 1., 1., 2., 2., 2.,\n",
       "       2., 2., 2., 2., 2., 2.])"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "protein_ohsu_kki = proteins+kki+ohsu\n",
    "gt_protein_ohsu_kki = np.zeros(len(proteins)+len(kki)+len(ohsu))\n",
    "gt_protein_ohsu_kki[:len(proteins)] = 0\n",
    "gt_protein_ohsu_kki[len(proteins):len(proteins)+len(kki)] = 1\n",
    "gt_protein_ohsu_kki[len(proteins)+len(kki):] = 2\n",
    "gt_protein_ohsu_kki"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Iotzg2xpAhC_",
    "outputId": "5313cd60-ac11-419b-b3f4-a173c3590ab9"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 1., 1., 1., 1., 1., 1., 1., 2., 2., 2.,\n",
       "       2., 2., 2., 2., 2., 2.])"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "protein_ohsu_peking = proteins+peking+ohsu\n",
    "gt_protein_ohsu_peking = np.zeros(len(proteins)+len(peking)+len(ohsu))\n",
    "gt_protein_ohsu_peking[:len(proteins)] = 0\n",
    "gt_protein_ohsu_peking[len(proteins):len(proteins)+len(peking)] = 1\n",
    "gt_protein_ohsu_peking[len(proteins)+len(peking):] = 2\n",
    "gt_protein_ohsu_peking"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Z5juMZ2VAhC_",
    "outputId": "6c0d8cf8-c247-4f13-a7cf-8748e9683638"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 1., 1., 1., 1., 1., 1., 1., 2., 2., 2.,\n",
       "       2., 2., 2., 2.])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "protein_kki_peking = proteins+peking+kki\n",
    "gt_protein_kki_peking = np.zeros(len(proteins)+len(peking)+len(kki))\n",
    "gt_protein_kki_peking[:len(proteins)] = 0\n",
    "gt_protein_kki_peking[len(proteins):len(proteins)+len(peking)] = 1\n",
    "gt_protein_kki_peking[len(proteins)+len(peking):] = 2\n",
    "gt_protein_kki_peking"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "1_llpHEfAhDA",
    "outputId": "8c91de1b-0b83-487a-df91-de1805cd908b"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 0., 0., 1., 1., 1., 1., 1., 1., 1., 2.,\n",
       "       2., 2., 2., 2., 2., 2.])"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ohsu_kki_peking = ohsu+peking+kki\n",
    "gt_ohsu_kki_peking = np.zeros(len(ohsu)+len(peking)+len(kki))\n",
    "gt_ohsu_kki_peking[:len(ohsu)] = 0\n",
    "gt_ohsu_kki_peking[len(ohsu):len(ohsu)+len(peking)] = 1\n",
    "gt_ohsu_kki_peking[len(ohsu)+len(peking):] = 2\n",
    "gt_ohsu_kki_peking"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "XTWvc3SAAhDA",
    "outputId": "4451645f-4f91-4468-f027-3813b0767030"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 1., 1., 1., 1., 1., 1., 1., 2., 2., 2.,\n",
       "       2., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2.])"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "protein_ohsu_kki_peking = proteins+kki+ohsu+peking\n",
    "gt_protein_ohsu_kki_peking = np.zeros(len(proteins)+len(kki)+len(ohsu)+len(peking))\n",
    "gt_protein_ohsu_kki_peking[:len(proteins)] = 0\n",
    "gt_protein_ohsu_kki_peking[len(proteins):len(proteins)+len(kki)] = 1\n",
    "gt_protein_ohsu_kki_peking[len(proteins)+len(kki):len(proteins)+len(kki)+len(ohsu)] = 2\n",
    "gt_protein_ohsu_kki_peking[len(proteins)+len(kki)+len(ohsu):] = 2\n",
    "gt_protein_ohsu_kki_peking"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 350
    },
    "id": "gXm6frgnAhDA",
    "outputId": "9c8da955-d6df-44b4-e183-49e8f9e86904"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading graph dataset: facebook_ct1\n",
      "Loaded and the total number of graphs are  350\n",
      "max num of nodes is  100\n",
      "total graphs  350\n",
      "histogram of number of nodes in  facebook_ct1\n"
     ]
    },
    {
     "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": [
    "fb = load_graph(min_num_nodes=100, name='facebook_ct1')\n",
    "fb = fb[:10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 350
    },
    "id": "momFI362AhDB",
    "outputId": "0a53c686-b8cb-495a-939d-1d7ca3bc2880"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading graph dataset: github_stargazers\n",
      "Loaded and the total number of graphs are  8\n",
      "max num of nodes is  957\n",
      "total graphs  8\n",
      "histogram of number of nodes in  github_stargazers\n"
     ]
    },
    {
     "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": [
    "github = load_graph(min_num_nodes=950, name='github_stargazers')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 350
    },
    "id": "mUP2myyBAhDB",
    "outputId": "8b6a05eb-1d9b-423b-b6cf-233d6e588321"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading graph dataset: deezer_ego_nets\n",
      "Loaded and the total number of graphs are  10\n",
      "max num of nodes is  363\n",
      "total graphs  10\n",
      "histogram of number of nodes in  deezer_ego_nets\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXoAAAD4CAYAAADiry33AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAUZ0lEQVR4nO3df7BcZ33f8fcnsmyaQLGJLsEjS5YhzgQn4B+5FWSgxabBlp3UIpN0IpeCoTCacXESSCYdO8zYrZnOmLgTMiQmRg0ah5TYEMCJOsjYajFxWiKja8e/f3FxnFqKO1YQGKgpHplv/9ijcny9V3elu3ev/Pj9mtnROc9zzu53H9397NmzZ89JVSFJatcPLXcBkqSlZdBLUuMMeklqnEEvSY0z6CWpcUctdwHDrFq1qtatW7fcZUjS88btt9/+D1U1NazviAz6devWMTMzs9xlSNLzRpK/m6/PXTeS1DiDXpIaZ9BLUuMMeklqnEEvSY0z6CWpcQsGfZI1SW5Jcn+S+5L8+pBlkuQjSWaT3J3kjF7fhUm+2t0uHPcTkCQd3CjH0e8HfrOq7kjyEuD2JDuq6v7eMucCJ3e31wF/CLwuycuAy4FpoLp1t1XVN8b6LCRJ81pwi76qHq+qO7rpbwMPAKvnLLYR+EQN7ASOTXI8cA6wo6r2deG+A9gw1mcgSTqoQ/plbJJ1wOnAbXO6VgOP9eZ3d23ztQ+7783AZoC1a9ceSlnPsu6Szx/2uovx6JU/vyyPCy/M57xcHGs9H438ZWySFwOfBd5XVd8adyFVtaWqpqtqempq6OkaJEmHYaSgT7KSQch/sqo+N2SRPcCa3vwJXdt87ZKkCRnlqJsAHwceqKrfnWexbcA7uqNvXg88WVWPAzcBZyc5LslxwNldmyRpQkbZR/8G4O3APUnu7Np+G1gLUFXXANuB84BZ4CngXV3fviQfBHZ1611RVfvGV74kaSELBn1V/Q8gCyxTwHvn6dsKbD2s6iRJi+YvYyWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWqcQS9JjVvwwiNJtgK/ADxRVT89pP+3gLf17u/VwFR3dalHgW8DzwD7q2p6XIVLkkYzyhb9tcCG+Tqr6qqqOq2qTgMuBf5yzuUCz+r6DXlJWgYLBn1V3QqMep3XC4DrFlWRJGmsxraPPskPM9jy/2yvuYCbk9yeZPO4HkuSNLoF99Efgn8B/M85u23eWFV7krwc2JHkwe4TwnN0bwSbAdauXTvGsiTphW2cR91sYs5um6ra0/37BHADsH6+latqS1VNV9X01NTUGMuSpBe2sQR9kpcCbwL+otf2I0lecmAaOBu4dxyPJ0ka3SiHV14HnAmsSrIbuBxYCVBV13SL/SJwc1X9n96qPwbckOTA4/xpVX1hfKVLkkaxYNBX1QUjLHMtg8Mw+22PAKcebmGSpPHwl7GS1DiDXpIaZ9BLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUuAWDPsnWJE8kGXq91yRnJnkyyZ3d7bJe34YkDyWZTXLJOAuXJI1mlC36a4ENCyzzV1V1Wne7AiDJCuBq4FzgFOCCJKcsplhJ0qFbMOir6lZg32Hc93pgtqoeqaqngeuBjYdxP5KkRRjXPvqfTXJXkhuT/FTXthp4rLfM7q5tqCSbk8wkmdm7d++YypIkjSPo7wBOrKpTgd8H/vxw7qSqtlTVdFVNT01NjaEsSRKMIeir6ltV9Z1uejuwMskqYA+wprfoCV2bJGmCFh30SV6RJN30+u4+vw7sAk5OclKSo4FNwLbFPp4k6dActdACSa4DzgRWJdkNXA6sBKiqa4BfBi5Ksh/4LrCpqgrYn+Ri4CZgBbC1qu5bkmchSZrXgkFfVRcs0P8HwB/M07cd2H54pUmSxsFfxkpS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIaZ9BLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjFgz6JFuTPJHk3nn635bk7iT3JPlyklN7fY927XcmmRln4ZKk0YyyRX8tsOEg/X8LvKmqXgN8ENgyp/+sqjqtqqYPr0RJ0mKMcs3YW5OsO0j/l3uzO4ETFl+WJGlcxr2P/t3Ajb35Am5OcnuSzQdbMcnmJDNJZvbu3TvmsiTphWvBLfpRJTmLQdC/sdf8xqrak+TlwI4kD1bVrcPWr6otdLt9pqena1x1SdIL3Vi26JO8FvgjYGNVff1Ae1Xt6f59ArgBWD+Ox5MkjW7RQZ9kLfA54O1V9XCv/UeSvOTANHA2MPTIHUnS0llw102S64AzgVVJdgOXAysBquoa4DLgR4GPJgHY3x1h82PADV3bUcCfVtUXluA5SJIOYpSjbi5YoP89wHuGtD8CnPrcNSRJk+QvYyWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxIwV9kq1Jnkgy9JqvGfhIktkkdyc5o9d3YZKvdrcLx1W4JGk0o27RXwtsOEj/ucDJ3W0z8IcASV7G4BqzrwPWA5cnOe5wi5UkHbqRgr6qbgX2HWSRjcAnamAncGyS44FzgB1Vta+qvgHs4OBvGJKkMVvw4uAjWg081pvf3bXN1/4cSTYz+DTA2rVrx1TW5Ky75PPLXcLELedzfvTKn1+2x9ZkvBBfU0v1d33EfBlbVVuqarqqpqemppa7HElqxriCfg+wpjd/Qtc2X7skaULGFfTbgHd0R9+8Hniyqh4HbgLOTnJc9yXs2V2bJGlCRtpHn+Q64ExgVZLdDI6kWQlQVdcA24HzgFngKeBdXd++JB8EdnV3dUVVHexLXUnSmI0U9FV1wQL9Bbx3nr6twNZDL02SNA5HzJexkqSlYdBLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekho3UtAn2ZDkoSSzSS4Z0v/hJHd2t4eTfLPX90yvb9s4i5ckLWzBSwkmWQFcDbwF2A3sSrKtqu4/sExVvb+3/K8Cp/fu4rtVddr4SpYkHYpRtujXA7NV9UhVPQ1cD2w8yPIXANeNozhJ0uKNEvSrgcd687u7tudIciJwEvDFXvOLkswk2ZnkrfM9SJLN3XIze/fuHaEsSdIoxv1l7CbgM1X1TK/txKqaBv4V8HtJXjVsxaraUlXTVTU9NTU15rIk6YVrlKDfA6zpzZ/QtQ2ziTm7bapqT/fvI8CXePb+e0nSEhsl6HcBJyc5KcnRDML8OUfPJPlJ4Djgr3ttxyU5ppteBbwBuH/uupKkpbPgUTdVtT/JxcBNwApga1Xdl+QKYKaqDoT+JuD6qqre6q8GPpbk+wzeVK7sH60jSVp6CwY9QFVtB7bPabtszvy/H7Lel4HXLKI+SdIi+ctYSWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIaZ9BLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJatxIQZ9kQ5KHkswmuWRI/zuT7E1yZ3d7T6/vwiRf7W4XjrN4SdLCFryUYJIVwNXAW4DdwK4k24Zc+/VTVXXxnHVfBlwOTAMF3N6t+42xVC9JWtAoW/TrgdmqeqSqngauBzaOeP/nADuqal8X7juADYdXqiTpcIwS9KuBx3rzu7u2uX4pyd1JPpNkzSGuS5LNSWaSzOzdu3eEsiRJoxjXl7H/FVhXVa9lsNX+x4d6B1W1paqmq2p6ampqTGVJkkYJ+j3Amt78CV3b/1dVX6+q73WzfwT8zKjrSpKW1ihBvws4OclJSY4GNgHb+gskOb43ez7wQDd9E3B2kuOSHAec3bVJkiZkwaNuqmp/kosZBPQKYGtV3ZfkCmCmqrYBv5bkfGA/sA94Z7fuviQfZPBmAXBFVe1bguchSZrHgkEPUFXbge1z2i7rTV8KXDrPuluBrYuoUZK0CP4yVpIaZ9BLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekho3UtAn2ZDkoSSzSS4Z0v8bSe5PcneS/57kxF7fM0nu7G7b5q4rSVpaC15KMMkK4GrgLcBuYFeSbVV1f2+xvwGmq+qpJBcBvwP8Stf33ao6bcx1S5JGNMoW/XpgtqoeqaqngeuBjf0FquqWqnqqm90JnDDeMiVJh2uUoF8NPNab3921zefdwI29+RclmUmyM8lb51spyeZuuZm9e/eOUJYkaRQL7ro5FEn+NTANvKnXfGJV7UnySuCLSe6pqq/NXbeqtgBbAKanp2ucdUnSC9koW/R7gDW9+RO6tmdJ8nPAB4Dzq+p7B9qrak/37yPAl4DTF1GvJOkQjRL0u4CTk5yU5GhgE/Cso2eSnA58jEHIP9FrPy7JMd30KuANQP9LXEnSEltw101V7U9yMXATsALYWlX3JbkCmKmqbcBVwIuBP0sC8L+q6nzg1cDHknyfwZvKlXOO1pEkLbGR9tFX1XZg+5y2y3rTPzfPel8GXrOYAiVJi+MvYyWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxIwV9kg1JHkoym+SSIf3HJPlU139bknW9vku79oeSnDO+0iVJo1gw6JOsAK4GzgVOAS5Icsqcxd4NfKOqfhz4MPChbt1TGFxM/KeADcBHu/uTJE3IKFv064HZqnqkqp4Grgc2zllmI/DH3fRngH+ewVXCNwLXV9X3qupvgdnu/iRJEzLKxcFXA4/15ncDr5tvmaran+RJ4Ee79p1z1l097EGSbAY2d7PfSfLQCLVN2irgH5a7iIM4kusba2350LjuCXgejNuYn+84HfFjt9xFzGNobYv8fz5xvo5Rgn4iqmoLsGW56ziYJDNVNb3cdcznSK7P2g7PkVwbHNn1WdsPjLLrZg+wpjd/Qtc2dJkkRwEvBb4+4rqSpCU0StDvAk5OclKSoxl8ubptzjLbgAu76V8GvlhV1bVv6o7KOQk4GfjKeEqXJI1iwV033T73i4GbgBXA1qq6L8kVwExVbQM+DvxJkllgH4M3A7rlPg3cD+wH3ltVzyzRc5mEI3rXEkd2fdZ2eI7k2uDIrs/aOhlseEuSWuUvYyWpcQa9JDXOoO9JsibJLUnuT3Jfkl/v2q9K8mCSu5PckOTY3joTOcXDfLX1+n8zSSVZ1c0nyUe62u5OcsZy1JbkV7uxuy/J7/Tal3XckpyWZGeSO5PMJFnftU9s3LrHe1GSryS5q6vvP3TtJ3WnE5ntTi9ydNc+7+lGJljbJ7v/t3uTbE2ysmuf5N/c0Np6/R9J8p3e/MTG7WD1dWP0H5M8nOSBJL/Wa1+6sasqb90NOB44o5t+CfAwg9M+nA0c1bV/CPhQN30KcBdwDHAS8DVgxSRr6+bXMPiy/O+AVV3becCNQIDXA7ctw7idBfw34Jiu7+VHyrgBNwPn9sbqS5Met+7xAry4m14J3NY97qeBTV37NcBF3fS/Ba7ppjcBn1qG2s7r+gJc16ttkn9zQ2vr5qeBPwG+01t+YuO2wNi9C/gE8ENzXhNLOnZu0fdU1eNVdUc3/W3gAWB1Vd1cVfu7xXYy+D0ATPAUD/PV1nV/GPh3QP+b9Y3AJ2pgJ3BskuMnXNtFwJVV9b2u74lebcs9bgX8426xlwJ/36ttIuPW1VRVdWDLc2V3K+DNDE4nAoPTi7y1V9+w041MrLaq2t71FYPDpfuvh0n9zQ2tLYNzaV3F4PXQN7FxO1h9DF4TV1TV97vl+q+JJRs7g34e3Ue70xm8E/f9GwbvvDD89BBDT/GwVLUl2Qjsqaq75iy27LUBPwH80+6j8l8m+SdHUG3vA65K8hjwn4BLl6u2JCuS3Ak8Aexg8Annm72Ni34NzzrdCHDgdCMTqa2qbuv1rQTeDnxhbm1D6p5UbRcD26rq8TmLT3TcDlLfq4Bf6XYX3pjk5Ln1dcY6dgb9EEleDHwWeF9VfavX/gEGvwf45JFQW1fLbwOXLVc9fUPG7SjgZQw+iv4W8Oml3Io6xNouAt5fVWuA9zP4LciyqKpnquo0BlvG64GfXK5a5ppbW5Kf7nV/FLi1qv7qCKntnwH/Evj95ahnrnnG7hjg/9bg9Af/Gdg6iVoM+jm6rZTPAp+sqs/12t8J/ALwtu4jK0z4FA9DansVg33cdyV5tHv8O5K84gioDQZbJZ/rPo5+Bfg+g5M5HQm1XQgcmP4zfrDraNlO21FV3wRuAX6WwUf3Az9o7Ncw3+lGJlXbhu6xLwemgN/oLbYsY9er7Szgx4HZ7vXwwxn8iPNZtU1y3ObUt4HuNdF13QC8dm59nbGOnUHf021tfhx4oKp+t9e+gcE+v/Or6qneKhM7xcOw2qrqnqp6eVWtq6p1DP6Izqiq/93V9o7u2/zXA08O+Ti7ZLV1/pzBi48kPwEczeCMfcs6bp2/B97UTb8Z+Go3PbFx6+qbSncUV5J/BLyFwfcItzA4nQgM3pT+olffsNONTKq2B5O8BzgHuODAvuZebZP6mxtW2+1V9Yre6+GpGlwj40BtExm3g9T3IL3XBIO/v4d79S3d2NUSfvP8fLsBb2TwhcndwJ3d7TwGXxY+1mu7prfOBxjsU32I7iiOSdY2Z5lH+cFRN2FwwZivAfcA08swbkcD/wW4F7gDePORMm5d++0Mjv65DfiZSY9b93ivBf6mq+9e4LKu/ZUM3vxmGXziOHDk0ou6+dmu/5XLUNv+bnwOjOeB9kn+zQ2tbc4y/aNuJjZuC4zdscDnu/H5a+DUSYydp0CQpMa560aSGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMb9P+HYXO0Q6LwOAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "deezer = load_graph(min_num_nodes = 200, name = 'deezer_ego_nets')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 350
    },
    "id": "ST1r-piwAhDB",
    "outputId": "149f3022-47f2-4fcc-e6d5-011aafa70c82"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading graph dataset: REDDIT-BINARY\n",
      "Loaded and the total number of graphs are  12\n",
      "max num of nodes is  3782\n",
      "total graphs  12\n",
      "histogram of number of nodes in  REDDIT-BINARY\n"
     ]
    },
    {
     "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": [
    "reddit = load_graph(min_num_nodes=3200, name='REDDIT-BINARY')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Qq3BizecAhDB",
    "outputId": "bc561d7c-3663-4287-b5ac-a482d08d68fb"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2.])"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fb_github_reddit = fb + github + reddit\n",
    "gt_fb_github_reddit = np.zeros(len(fb)+len(github)+len(reddit))\n",
    "gt_fb_github_reddit[:len(fb)] = 0\n",
    "gt_fb_github_reddit[len(fb):len(fb)+len(github)] = 1\n",
    "gt_fb_github_reddit[len(fb)+len(github):] = 2\n",
    "gt_fb_github_reddit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "b4V5wEEKAhDC",
    "outputId": "2816fce5-a9b6-46f8-a37f-5bab5b9462d6"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2.])"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fb_github_deezer = fb + github + deezer\n",
    "gt_fb_github_deezer = np.zeros(len(fb)+len(github)+len(deezer))\n",
    "gt_fb_github_deezer[:len(fb)] = 0\n",
    "gt_fb_github_deezer[len(fb):len(fb)+len(github)] = 1\n",
    "gt_fb_github_deezer[len(fb)+len(github):]=2\n",
    "gt_fb_github_deezer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "pNgE24D7AhDC",
    "outputId": "4aacc324-cfdd-4e23-e7cb-acb675a55076"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2.])"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fb_reddit_deezer = fb + reddit + deezer\n",
    "gt_fb_reddit_deezer = np.zeros(len(fb)+len(reddit)+len(deezer))\n",
    "gt_fb_reddit_deezer[:len(fb)] = 0\n",
    "gt_fb_reddit_deezer[len(fb):len(fb)+len(reddit)] = 1\n",
    "gt_fb_reddit_deezer[len(fb)+len(reddit):]=2\n",
    "gt_fb_reddit_deezer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "3GzxPT5fAhDD",
    "outputId": "d32e29be-bb05-4492-b3f2-46edc148cd2e"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 0., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2.])"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "github_reddit_deezer = github + reddit + deezer\n",
    "gt_github_reddit_deezer = np.zeros(len(github)+len(reddit)+len(deezer))\n",
    "gt_github_reddit_deezer[:len(github)] = 0\n",
    "gt_github_reddit_deezer[len(github):len(github)+len(reddit)] = 1\n",
    "gt_github_reddit_deezer[len(github)+len(reddit):]=2\n",
    "gt_github_reddit_deezer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "HvlsS1QEAhDD",
    "outputId": "db2682ea-9960-4de2-9815-d7fa2d37bf7f"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2., 2., 3., 3., 3., 3.,\n",
       "       3., 3., 3., 3., 3., 3.])"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fb_github_reddit_deezer = fb + github + reddit + deezer\n",
    "gt_fb_github_reddit_deezer = np.zeros(len(fb)+len(github)+len(reddit)+len(deezer))\n",
    "gt_fb_github_reddit_deezer[:len(fb)] = 0\n",
    "gt_fb_github_reddit_deezer[len(fb):len(fb)+len(github)] = 1\n",
    "gt_fb_github_reddit_deezer[len(fb)+len(github):len(fb)+len(github)+len(reddit)] = 2\n",
    "gt_fb_github_reddit_deezer[len(fb)+len(github)+len(reddit):]=3\n",
    "gt_fb_github_reddit_deezer"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "z3NaTr9PAhDD"
   },
   "source": [
    "## Evaluate algorithms - real data\n",
    "\n",
    "* pass `graphs='dataset_combination'`, `gt='gt_dataset_combination'`, `num_clusters=3 or 4` depending on the dataset combination in each of the following algorithm evaluation to get the reported result"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "NcanGC7Ii1iS"
   },
   "source": [
    "### protein_ohsu_kki"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "kYO-6j5NBdxn",
    "outputId": "e12b49ff-9102-4d52-f71e-62c38e6f2251"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time for NCLM  0.16915297508239746\n",
      "NCLM: err and ari  [0.26086956521739135] [0.443956043956044]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err, ari = simulate_nclm(graphs=protein_ohsu_kki, gt=gt_protein_ohsu_kki,j=[8],num_clusters=3)\n",
    "print('NCLM: err and ari ', err,ari)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "1Q44Xy_pTFlX",
    "outputId": "bb3390d5-3d70-4412-9ee0-c802c4123d4e"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time for hist appr  1.039654016494751\n",
      "Time for DSC  1.1052944660186768\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time SSDC  1.2491164207458496\n",
      "spec error for sigma  30 5 0.08695652173913049\n",
      "err, ari spect   [0.04347826] [0.8624551484179623]\n",
      "error sdp all sigmas  [[0.08695652173913049]]\n",
      "rand idx all sigmas  [[0.7405128205128205]]\n",
      "DSC (ours) err, ari  [0.04347826] [0.8624551484179623]\n",
      "SSDP (ours) err, ari  [[0.08695652173913049]] [[0.7405128205128205]]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err_spect, err_sdp, ari_spect, ari_sdp = simulate_histogram(graphs=protein_ohsu_kki,gt=gt_protein_ohsu_kki,check_n0=[30],sigma=[5],num_clusters=3)\n",
    "print('DSC (ours) err, ari ', err_spect, ari_spect)\n",
    "print('SSDP (ours) err, ari ', err_sdp, ari_sdp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "bmtT013M2FfR",
    "outputId": "6fc9dbd2-1709-4ffa-a46d-ddbcedcaa1a2"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "No label attributed to graphs, use degree instead and use CONTINUOUS propagation scheme.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/numpy/core/_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time for WWL  2.536400079727173\n",
      "wwl error  0.30434782608695654\n",
      "wwl rand idx   0.3628134467277439\n",
      "WWLGK err, ari  0.30434782608695654 0.3628134467277439\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err, ari = simulate_wwlgk(graphs_tensor=protein_ohsu_kki, gt=gt_protein_ohsu_kki,num_clusters=3)\n",
    "print('WWLGK err, ari ',err, ari)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "vJtQf7Tq2ybh",
    "outputId": "6a549672-016b-4951-dfe7-6c399b8a5dec"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "skipped graphs  []\n",
      "reduced graphs  23 torch.Size([336, 3])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:363: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  v = np.divide(b, KtransposeU)\n",
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:363: RuntimeWarning: overflow encountered in true_divide\n",
      "  v = np.divide(b, KtransposeU)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:364: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  u = 1. / np.dot(Kp, v)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 12\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 26\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "mmd calculated\n",
      "Time for NCMMD  20.716872453689575\n",
      "err, ri  0.26086956521739135 0.370453693288339\n",
      "NCMMD err, ari  [0.26086956521739135] [0.370453693288339]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err, ari, _ = simulate_ncmmd(graphs=protein_ohsu_kki, gt=gt_protein_ohsu_kki, rank=[3], num_clusters=3)\n",
    "print('NCMMD err, ari ', err, ari)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "r17O3jem4G4K",
    "outputId": "c338962d-0bac-469c-fc3a-d03210c7acce"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gram matrix computed!  (23, 23)\n",
      "Time for GNTK  28.21137833595276\n",
      "sc error is  0.26086956521739135\n",
      "sc Rand idx   0.443956043956044\n",
      "GNTK err, ari  0.26086956521739135 0.443956043956044\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err, ari = simulate_gntk(graphs=protein_ohsu_kki, gt=gt_protein_ohsu_kki, num_clusters=3)\n",
    "print('GNTK err, ari ', err, ari)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### protein_ohsu_kki_peking"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "nN7huM2vj59o",
    "outputId": "3fc9de4b-a928-4309-9594-2f72b978548d"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time for NCLM  0.18267464637756348\n",
      "NCLM: err and ari  [0.33333333333333337] [0.3432830498199066]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err, ari = simulate_nclm(graphs=protein_ohsu_kki_peking, gt=gt_protein_ohsu_kki_peking,j=[8],num_clusters=4)\n",
    "print('NCLM: err and ari ', err,ari)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "pnIct9-rj59p",
    "outputId": "71eb49a8-37b5-4cef-8955-96a4ec922a71"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time for hist appr  1.252903938293457\n",
      "Time for DSC  1.3351857662200928\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time SSDC  1.4608254432678223\n",
      "spec error for sigma  30 5 0.33333333333333337\n",
      "err, ari spect   [0.06666667] [0.8216116465039983]\n",
      "error sdp all sigmas  [[0.33333333333333337]]\n",
      "rand idx all sigmas  [[0.3635233008998463]]\n",
      "DSC (ours) err, ari  [0.06666667] [0.8216116465039983]\n",
      "SSDP (ours) err, ari  [[0.33333333333333337]] [[0.3635233008998463]]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err_spect, err_sdp, ari_spect, ari_sdp = simulate_histogram(graphs=protein_ohsu_kki_peking,gt=gt_protein_ohsu_kki_peking,check_n0=[30],sigma=[5],num_clusters=4)\n",
    "print('DSC (ours) err, ari ', err_spect, ari_spect)\n",
    "print('SSDP (ours) err, ari ', err_sdp, ari_sdp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "LvmeuqQmj59q",
    "outputId": "e6cde303-1325-43b6-8f1a-6ea4d1d3a8b1"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "No label attributed to graphs, use degree instead and use CONTINUOUS propagation scheme.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/numpy/core/_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time for WWL  3.1915431022644043\n",
      "wwl error  0.43333333333333335\n",
      "wwl rand idx   0.25340198602427366\n",
      "WWLGK err, ari  0.43333333333333335 0.25340198602427366\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err, ari = simulate_wwlgk(graphs_tensor=protein_ohsu_kki_peking, gt=gt_protein_ohsu_kki_peking,num_clusters=4)\n",
    "print('WWLGK err, ari ',err, ari)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "GXmYR5d1j59q",
    "outputId": "bda89c0b-562e-4f36-d056-094a7189bf67"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "skipped graphs  []\n",
      "reduced graphs  30 torch.Size([336, 3])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:363: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  v = np.divide(b, KtransposeU)\n",
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:363: RuntimeWarning: overflow encountered in true_divide\n",
      "  v = np.divide(b, KtransposeU)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:364: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  u = 1. / np.dot(Kp, v)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 12\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 26\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 5\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "mmd calculated\n",
      "Time for NCMMD  28.66017174720764\n",
      "err, ri  0.43333333333333335 0.23391474270825793\n",
      "NCMMD err, ari  [0.43333333333333335] [0.23391474270825793]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err, ari, _ = simulate_ncmmd(graphs=protein_ohsu_kki_peking, gt=gt_protein_ohsu_kki_peking, rank=[3], num_clusters=4)\n",
    "print('NCMMD err, ari ', err, ari)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "B_YF4U3qj59r",
    "outputId": "e3430a7b-49ca-4df1-df7e-4a7760db944e"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gram matrix computed!  (30, 30)\n",
      "Time for GNTK  40.18471837043762\n",
      "sc error is  0.4\n",
      "sc Rand idx   0.2873386150234742\n",
      "GNTK err, ari  0.4 0.2873386150234742\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err, ari = simulate_gntk(graphs=protein_ohsu_kki_peking, gt=gt_protein_ohsu_kki_peking, num_clusters=4)\n",
    "print('GNTK err, ari ', err, ari)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "I1tXD4graqWg",
    "outputId": "f93c7434-b9f1-40ec-c1bf-7853420589d0"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dist of matched graphs calculated\n",
      "Time for NCGMP  219.58516645431519\n",
      "err, ri GMP  0.17391304347826086 0.567459752101439\n",
      "NCGMP err , ari  0.17391304347826086 0.567459752101439\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err, ari, _ = simulate_ncgmm(graphs=protein_ohsu_kki, gt=gt_protein_ohsu_kki, num_clusters=3)\n",
    "print('NCGMP err , ari ', err, ari)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Ufrz_QqeaqWo",
    "outputId": "ba3de04b-fdf3-44af-c6ed-477f98a5e157"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dist of matched graphs calculated\n",
      "Time for NCGMP  278.8006465435028\n",
      "err, ri GMP  0.3666666666666667 0.340220432100846\n",
      "NCGMP err , ari  0.3666666666666667 0.340220432100846\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "err, ari, _ = simulate_ncgmp(graphs=protein_ohsu_kki_peking, gt=gt_protein_ohsu_kki_peking, num_clusters=4)\n",
    "print('NCGMP err , ari ', err, ari)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "1g9xOYBW_YAB"
   },
   "source": [
    "## Evaluate algorithms - simulated data\n",
    "\n",
    "* pass different `graphons` list, change `num_clusters` accordingly.\n",
    "* for demonstration we have set `simulation=1`, change it to 5 or 10 as discussed in the paper.\n",
    "* similarly, change `number_of_graphs` to be generated from each graphon\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "id": "_543FX9qAhDE"
   },
   "outputs": [],
   "source": [
    "def evaluate_simulated_data(graphons, check_n0=[10], number_of_graphs=10, num_clusters=3, simulation=5):\n",
    "    err_spect = []\n",
    "    err_sdp = []\n",
    "    ri_spect = []\n",
    "    ri_sdp = []\n",
    "    err_nclm = []\n",
    "    ri_nclm = []\n",
    "    err_wwl = []\n",
    "    ri_wwl = []\n",
    "    err_ncmmd = []\n",
    "    ri_ncmmd = []\n",
    "    err_gntk = []\n",
    "    ri_gntk = []\n",
    "    err_ncgmp = []\n",
    "    ri_ncgmp = []\n",
    "    for i in range(simulation):\n",
    "        print('simulation ', i)\n",
    "        graphs, gt_graphs = data_simulation(graphons, number_of_graphs=number_of_graphs, start=50,stop=100)\n",
    "        err_graphs_spect, err_graphs_sdp, ri_g_spect, ri_g_sdp = simulate_histogram(graphs=graphs, gt=gt_graphs, check_n0=check_n0, sigma=[5], num_clusters=num_clusters)\n",
    "        err_lm, ri_lm = simulate_nclm(graphs, gt_graphs, j=[8], num_clusters=num_clusters)\n",
    "        err_g_wwl, ri_g_wwl = simulate_wwlgk(graphs, gt_graphs, num_clusters=num_clusters)\n",
    "        mmd_err_g, mmd_ri_g, _  = simulate_ncmmd(graphs, gt_graphs, rank=[3], num_clusters=num_clusters)\n",
    "        e_gntk, r_gntk = simulate_gntk(graphs, gt_graphs,num_clusters=num_clusters,num_layers=1, num_mlp_layers=1)\n",
    "        e_ncgmp, r_ncgmp, _ = simulate_ncgmp(graphs, gt_graphs, num_clusters=num_clusters)\n",
    "\n",
    "        err_spect.append(err_graphs_spect)\n",
    "        err_sdp.append(err_graphs_sdp)\n",
    "        ri_spect.append(ri_g_spect)\n",
    "        ri_sdp.append(ri_g_sdp)\n",
    "        err_nclm.append(err_lm)\n",
    "        ri_nclm.append(ri_lm)\n",
    "        err_wwl.append(err_g_wwl)\n",
    "        ri_wwl.append(ri_g_wwl)\n",
    "        err_ncmmd.append(mmd_err_g)\n",
    "        ri_ncmmd.append(mmd_ri_g)\n",
    "        err_gntk.append(e_gntk)\n",
    "        ri_gntk.append(r_gntk)\n",
    "        err_ncgmp.append(e_ncgmp)\n",
    "        ri_ncgmp.append(r_ncgmp)\n",
    "\n",
    "    return err_spect, err_sdp, ri_spect, ri_sdp, err_nclm, ri_nclm, err_wwl, ri_wwl, err_ncmmd, ri_ncmmd, err_gntk, ri_gntk, err_ncgmp, ri_ncgmp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "sOsiJJooAhDF",
    "outputId": "772a03d5-db30-41df-986a-4db043cacbfd"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "simulation  0\n",
      "nodes  tensor([76, 64, 82, 92, 65])\n",
      "nodes  tensor([72, 87, 78, 68, 93])\n",
      "nodes  tensor([59, 88, 67, 74, 64])\n",
      "nodes  tensor([79, 64, 60, 61, 95])\n",
      "graphs generated 20\n",
      "true labels  [0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 2.0, 2.0, 2.0, 2.0, 2.0, 3.0, 3.0, 3.0, 3.0, 3.0]\n",
      "Time for hist appr  0.055411338806152344\n",
      "Time for DSC  0.09362363815307617\n",
      "Time SSDC  0.12720727920532227\n",
      "spec error for sigma  10 3 0.4\n",
      "err, ari spect   [0.1] [0.7556270096463023]\n",
      "error sdp all sigmas  [[0.4]]\n",
      "rand idx all sigmas  [[0.4123711340206186]]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/usr/local/lib/python3.7/dist-packages/numpy/core/_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time for NCLM  0.08015990257263184\n",
      "No label attributed to graphs, use degree instead and use CONTINUOUS propagation scheme.\n",
      "Time for WWL  0.30510807037353516\n",
      "wwl error  0.55\n",
      "wwl rand idx   0.14304123711340208\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "skipped graphs  []\n",
      "reduced graphs  20 torch.Size([76, 3])\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:363: RuntimeWarning: overflow encountered in true_divide\n",
      "  v = np.divide(b, KtransposeU)\n",
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:364: RuntimeWarning: overflow encountered in true_divide\n",
      "  u = 1. / np.dot(Kp, v)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: numerical errors at iteration 23\n",
      "Warning: numerical errors at iteration 18\n",
      "Warning: numerical errors at iteration 17\n",
      "Warning: numerical errors at iteration 11\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:363: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  v = np.divide(b, KtransposeU)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 5\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 27\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "mmd calculated\n",
      "Time for NCMMD  3.6266543865203857\n",
      "err, ri  0.35 0.581973030518098\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/content/drive/My Drive/MS_TUM/Guided Research/graph_clustering/GNTK.py:32: RuntimeWarning: invalid value encountered in true_divide\n",
      "  S = S / diag[:, None] / diag[None, :]\n",
      "/content/drive/My Drive/MS_TUM/Guided Research/graph_clustering/GNTK.py:54: RuntimeWarning: invalid value encountered in true_divide\n",
      "  S = S / diag1[:, None] / diag2[None, :]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gram matrix computed!  (20, 20)\n",
      "Time for GNTK  85.34616208076477\n",
      "sc error is  0.44999999999999996\n",
      "sc Rand idx   0.2622710622710623\n",
      "simulation  1\n",
      "nodes  tensor([86, 93, 64, 71, 81])\n",
      "nodes  tensor([56, 57, 94, 85, 81])\n",
      "nodes  tensor([64, 99, 90, 74, 83])\n",
      "nodes  tensor([86, 77, 57, 61, 69])\n",
      "graphs generated 20\n",
      "true labels  [0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 2.0, 2.0, 2.0, 2.0, 2.0, 3.0, 3.0, 3.0, 3.0, 3.0]\n",
      "Time for hist appr  0.053812265396118164\n",
      "Time for DSC  0.09046339988708496\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time SSDC  0.13718700408935547\n",
      "spec error for sigma  10 3 0.4\n",
      "err, ari spect   [0.05] [0.8587943848059455]\n",
      "error sdp all sigmas  [[0.4]]\n",
      "rand idx all sigmas  [[0.4123711340206186]]\n",
      "Time for NCLM  0.07769250869750977\n",
      "No label attributed to graphs, use degree instead and use CONTINUOUS propagation scheme.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/usr/local/lib/python3.7/dist-packages/numpy/core/_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time for WWL  0.32876157760620117\n",
      "wwl error  0.6\n",
      "wwl rand idx   0.042748091603053415\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "skipped graphs  []\n",
      "reduced graphs  20 torch.Size([86, 3])\n",
      "Warning: numerical errors at iteration 86\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:364: RuntimeWarning: overflow encountered in true_divide\n",
      "  u = 1. / np.dot(Kp, v)\n",
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:363: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  v = np.divide(b, KtransposeU)\n",
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:363: RuntimeWarning: overflow encountered in true_divide\n",
      "  v = np.divide(b, KtransposeU)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: numerical errors at iteration 90\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 14\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 2\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 8\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 93\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "mmd calculated\n",
      "Time for NCMMD  3.843534469604492\n",
      "err, ri  0.30000000000000004 0.6149545772187281\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/content/drive/My Drive/MS_TUM/Guided Research/graph_clustering/GNTK.py:32: RuntimeWarning: invalid value encountered in true_divide\n",
      "  S = S / diag[:, None] / diag[None, :]\n",
      "/content/drive/My Drive/MS_TUM/Guided Research/graph_clustering/GNTK.py:54: RuntimeWarning: invalid value encountered in true_divide\n",
      "  S = S / diag1[:, None] / diag2[None, :]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gram matrix computed!  (20, 20)\n",
      "Time for GNTK  78.17756748199463\n",
      "sc error is  0.5\n",
      "sc Rand idx   0.1111864406779661\n",
      "simulation  2\n",
      "nodes  tensor([55, 82, 91, 70, 84])\n",
      "nodes  tensor([72, 86, 55, 95, 53])\n",
      "nodes  tensor([72, 70, 67, 52, 51])\n",
      "nodes  tensor([78, 53, 68, 61, 56])\n",
      "graphs generated 20\n",
      "true labels  [0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 2.0, 2.0, 2.0, 2.0, 2.0, 3.0, 3.0, 3.0, 3.0, 3.0]\n",
      "Time for hist appr  0.05553150177001953\n",
      "Time for DSC  0.09344029426574707\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time SSDC  0.1309525966644287\n",
      "spec error for sigma  10 3 0.19999999999999996\n",
      "err, ari spect   [0.3] [0.6149545772187281]\n",
      "error sdp all sigmas  [[0.19999999999999996]]\n",
      "rand idx all sigmas  [[0.6686046511627907]]\n",
      "Time for NCLM  0.0801689624786377\n",
      "No label attributed to graphs, use degree instead and use CONTINUOUS propagation scheme.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/usr/local/lib/python3.7/dist-packages/numpy/core/_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time for WWL  0.2702341079711914\n",
      "wwl error  0.55\n",
      "wwl rand idx   0.023827252419955345\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "skipped graphs  []\n",
      "reduced graphs  20 torch.Size([55, 3])\n",
      "Warning: numerical errors at iteration 28\n",
      "Warning: numerical errors at iteration 22\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:363: RuntimeWarning: overflow encountered in true_divide\n",
      "  v = np.divide(b, KtransposeU)\n",
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:364: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  u = 1. / np.dot(Kp, v)\n",
      "/usr/local/lib/python3.7/dist-packages/ot/bregman.py:363: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  v = np.divide(b, KtransposeU)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 56\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 4\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 11\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 30\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "Warning: numerical errors at iteration 0\n",
      "mmd calculated\n",
      "Time for NCMMD  3.3493027687072754\n",
      "err, ri  0.30000000000000004 0.6149545772187281\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n",
      "/content/drive/My Drive/MS_TUM/Guided Research/graph_clustering/GNTK.py:32: RuntimeWarning: invalid value encountered in true_divide\n",
      "  S = S / diag[:, None] / diag[None, :]\n",
      "/content/drive/My Drive/MS_TUM/Guided Research/graph_clustering/GNTK.py:54: RuntimeWarning: invalid value encountered in true_divide\n",
      "  S = S / diag1[:, None] / diag2[None, :]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gram matrix computed!  (20, 20)\n",
      "Time for GNTK  63.62959098815918\n",
      "sc error is  0.4\n",
      "sc Rand idx   0.1643835616438356\n",
      "avg hist spect  tensor([0.1500]) tensor([0.7431])\n",
      "avg hist sdp  tensor([[0.3333]]) tensor([[0.4978]])\n",
      "avg nclm  tensor([0.2333]) tensor([0.5180])\n",
      "avg wwlgk  tensor(0.5667) tensor(0.0699)\n",
      "avg ncmmd  tensor([0.3167]) tensor([0.6040])\n",
      "avg gntk  tensor(0.4500) tensor(0.1793)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/sklearn/utils/linear_assignment_.py:128: FutureWarning: The linear_assignment function is deprecated in 0.21 and will be removed from 0.23. Use scipy.optimize.linear_sum_assignment instead.\n",
      "  FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "m_err_g1234_spect, m_err_g1234_sdp, m_ri_g1234_spect, m_ri_g1234_sdp, m_err_lm_g1234, m_ri_lm_g1234, m_err_wwl_g1234, m_ri_wwl_g1234, m_err_fr_g1234, m_ri_fr_g1234, m_err_gntk_g1234, m_ri_gntk_g1234, m_err_ncgmp_g1234, m_ri_ncgmp_g1234  = evaluate_simulated_data([1,2,3,4], check_n0=[10], number_of_graphs=5, num_clusters=4, simulation=3)\n",
    "print(\"avg hist spect \",torch.mean(torch.Tensor(m_err_g1234_spect),dim=0),torch.mean(torch.Tensor(m_ri_g1234_spect),dim=0))\n",
    "print(\"avg hist sdp \",torch.mean(torch.Tensor(m_err_g1234_sdp),dim=0),torch.mean(torch.Tensor(m_ri_g1234_sdp),dim=0))\n",
    "print(\"avg nclm \",torch.mean(torch.Tensor(m_err_lm_g1234),dim=0),torch.mean(torch.Tensor(m_ri_lm_g1234),dim=0))\n",
    "print(\"avg wwlgk \",torch.mean(torch.Tensor(m_err_wwl_g1234),dim=0),torch.mean(torch.Tensor(m_ri_wwl_g1234),dim=0))\n",
    "print(\"avg ncmmd \",torch.mean(torch.Tensor(m_err_fr_g1234),dim=0),torch.mean(torch.Tensor(m_ri_fr_g1234),dim=0))\n",
    "print(\"avg gntk \",torch.mean(torch.Tensor(m_err_gntk_g1234),dim=0),torch.mean(torch.Tensor(m_ri_gntk_g1234),dim=0))\n",
    "print(\"avg ncgmp \",torch.mean(torch.Tensor(m_err_ncgmp_g1234),dim=0),torch.mean(torch.Tensor(m_ri_ncgmp_g1234),dim=0))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "9oH3apbyAhDG"
   },
   "source": [
    "## Two-sample testing\n",
    "\n",
    "* pass the graphon pair to be tested for `graphon1` and `graphon2` \n",
    "* increase `bootstrap=100` (order of 100) and `trials=200` "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "dGEkC5lSAhDG",
    "outputId": "bed0aa80-4e66-4c03-bb16-bde962d8c4fe"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trial  0\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 3.684542e+01\n",
      "    stopping criterion: RTOL\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 1.678336e+02\n",
      "    stopping criterion: RTOL\n",
      "T between graphs  tensor(0.2968, dtype=torch.float64)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p_val  tensor(0.0500)\n",
      "trial  1\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 3.627402e+01\n",
      "    stopping criterion: RTOL\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 1.662931e+02\n",
      "    stopping criterion: RTOL\n",
      "T between graphs  tensor(0.2891, dtype=torch.float64)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p_val  tensor(0.0500)\n",
      "trial  2\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 4.068187e+01\n",
      "    stopping criterion: RTOL\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 1.743703e+02\n",
      "    stopping criterion: RTOL\n",
      "T between graphs  tensor(0.2859, dtype=torch.float64)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p_val  tensor(0.0500)\n",
      "trial  3\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 4.088606e+01\n",
      "    stopping criterion: RTOL\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 1.725303e+02\n",
      "    stopping criterion: RTOL\n",
      "T between graphs  tensor(0.2939, dtype=torch.float64)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p_val  tensor(0.0500)\n",
      "trial  4\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 4.058257e+01\n",
      "    stopping criterion: RTOL\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 1.727872e+02\n",
      "    stopping criterion: RTOL\n",
      "T between graphs  tensor(0.2369, dtype=torch.float64)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p_val  tensor(0.0500)\n",
      "trial  5\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 3.516640e+01\n",
      "    stopping criterion: RTOL\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 1.692259e+02\n",
      "    stopping criterion: RTOL\n",
      "T between graphs  tensor(0.3254, dtype=torch.float64)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p_val  tensor(0.0500)\n",
      "trial  6\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 3.049333e+01\n",
      "    stopping criterion: RTOL\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 1.683091e+02\n",
      "    stopping criterion: RTOL\n",
      "T between graphs  tensor(0.3310, dtype=torch.float64)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p_val  tensor(0.0500)\n",
      "trial  7\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 3.820020e+01\n",
      "    stopping criterion: RTOL\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 1.681322e+02\n",
      "    stopping criterion: RTOL\n",
      "T between graphs  tensor(0.2422, dtype=torch.float64)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p_val  tensor(0.0500)\n",
      "trial  8\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 3.858890e+01\n",
      "    stopping criterion: RTOL\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 1.733575e+02\n",
      "    stopping criterion: RTOL\n",
      "T between graphs  tensor(0.2959, dtype=torch.float64)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p_val  tensor(0.0500)\n",
      "trial  9\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 4.000938e+01\n",
      "    stopping criterion: RTOL\n",
      "Solution found after 2 iterations:\n",
      "    objective function f(sol) = 1.687777e+02\n",
      "    stopping criterion: RTOL\n",
      "T between graphs  tensor(0.2769, dtype=torch.float64)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p estimated  tensor(0.) tensor(0.0500)\n",
      "p_val  tensor(0.0500)\n",
      "p_values  [tensor(0.0500), tensor(0.0500), tensor(0.0500), tensor(0.0500), tensor(0.0500), tensor(0.0500), tensor(0.0500), tensor(0.0500), tensor(0.0500), tensor(0.0500)]\n",
      "power  tensor(1.)\n"
     ]
    }
   ],
   "source": [
    "#graphon pair (1,2)\n",
    "p,power = bootstraping(graphon1=1,graphon2=2,n=50,m=100,n0=10,bootstrap=10,trials=10,alpha=0.05,s=500)\n",
    "print('p_values ', p)\n",
    "print('power ', power)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "OoXTezSJ5QG0"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "graph_clustering.ipynb",
   "provenance": [],
   "toc_visible": true
  },
  "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.6"
  },
  "latex_envs": {
   "LaTeX_envs_menu_present": true,
   "autoclose": false,
   "autocomplete": true,
   "bibliofile": "biblio.bib",
   "cite_by": "apalike",
   "current_citInitial": 1,
   "eqLabelWithNumbers": true,
   "eqNumInitial": 1,
   "hotkeys": {
    "equation": "Ctrl-E",
    "itemize": "Ctrl-I"
   },
   "labels_anchors": false,
   "latex_user_defs": false,
   "report_style_numbering": false,
   "user_envs_cfg": false
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
