{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import networkx as nx\n",
    "import numpy as np\n",
    "import random\n",
    "random.seed;\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy\n",
    "from scipy import sparse\n",
    "from scipy.sparse import linalg\n",
    "import time\n",
    "import math\n",
    "from scipy import stats\n",
    "from sklearn.cluster import KMeans\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "from random import shuffle\n",
    "\n",
    "import sys\n",
    "sys.path += ['/Package'] ### Specify the directory where the Package is\n",
    "from clustering_more import *\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load the datasets"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Labelled datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "karate = nx.read_gml('datasets/karate.gml', label = 'id')\n",
    "A_karate = np.array(nx.adjacency_matrix(karate).todense())\n",
    "classes_karate = nx.get_node_attributes(karate,'value')\n",
    "ck = np.zeros(len(classes_karate))\n",
    "for i in range(len(ck)):\n",
    "    ck[i] += classes_karate[i+1]\n",
    "classes_karate = ck.astype(int)\n",
    "\n",
    "\n",
    "dolphins = nx.read_gml('datasets/dolphins.gml', label = 'id')\n",
    "A_dolphins = np.array(nx.adjacency_matrix(dolphins).todense())\n",
    "classes_dolphins = nx.get_node_attributes(dolphins,'value')\n",
    "cp = np.zeros(len(A_dolphins))\n",
    "for i in range(len(cp)):\n",
    "    cp[i] = classes_dolphins[i]\n",
    "classes_dolphins = cp.astype(int)\n",
    "\n",
    "polbooks = nx.read_gml('datasets/polbooks.gml', label = 'id')\n",
    "A_polbooks = np.array(nx.adjacency_matrix(polbooks).todense())\n",
    "classes_polbooks = nx.get_node_attributes(polbooks,'value')\n",
    "cp = np.zeros(len(classes_polbooks))\n",
    "for i in range(len(cp)):\n",
    "    cp[i] = classes_polbooks[i]-1\n",
    "classes_polbooks = cp.astype(int)\n",
    "\n",
    "football = nx.read_gml('datasets/football.gml', label = 'id')\n",
    "A_football = np.array(nx.adjacency_matrix(football).todense())\n",
    "classes_football = nx.get_node_attributes(football,'value')\n",
    "cp = np.zeros(len(A_football))\n",
    "for i in range(len(cp)):\n",
    "    cp[i] = classes_football[i+1]-1\n",
    "classes_football = cp.astype(int)\n",
    "\n",
    "polblogs = nx.read_gml('datasets/polblogs.gml', label = 'id')\n",
    "A_polblogs = np.array(nx.adjacency_matrix(polblogs).todense())\n",
    "A_polblogs = np.delete(A_polblogs,0,axis = 0)\n",
    "A_polblogs = np.delete(A_polblogs,0,axis = 1)\n",
    "classes_polblogs = nx.get_node_attributes(polblogs,'value')\n",
    "cp = np.zeros(len(A_polblogs))\n",
    "for i in range(len(cp)):\n",
    "    cp[i] = classes_polblogs[i]\n",
    "classes_polblogs = cp.astype(int)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Choose the network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# A = A_karate.astype(float)\n",
    "# A = A_dolphins.astype(float)\n",
    "# A = A_polbooks.astype(float)\n",
    "# A = A_football.astype(float)\n",
    "A = A_polblogs.astype(float)\n",
    "\n",
    "\n",
    "\n",
    "# real_classes = classes_karate\n",
    "# real_classes = classes_dolphins\n",
    "# real_classes = classes_polbooks\n",
    "# real_classes = classes_football\n",
    "real_classes = classes_polblogs\n",
    "\n",
    "A = sparse.coo_matrix(A)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n = 1221\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": [
    "n = len(A.A)\n",
    "print('n = ' + str(n))\n",
    "plt.figure()\n",
    "d = np.sum(A.A, axis = 0)\n",
    "plt.hist(d,bins = 10*int(n**0.3), color = 'orange', alpha = 0.5)\n",
    "plt.title('Histogram of degree distribution')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test different methods"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Our method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completion : 100.0%\n",
      "Overlap: 0.9066339066339066\n"
     ]
    }
   ],
   "source": [
    "n_cycles = 12\n",
    "max_n_classes = 70\n",
    "percentage = 'yes'\n",
    "\n",
    "n_classes = len(np.unique(real_classes))\n",
    "\n",
    "classes, X, n_clusters, r_estimate  = BH(A, n_cycles,max_n_classes, n_classes, percentage)\n",
    "mod = modularity(A.A, classes)\n",
    "classes, ov = overlap(real_classes, classes)\n",
    "print('\\nOverlap: ' + str(ov))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Saade"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Overlap: 0.3218673218673218\n"
     ]
    }
   ],
   "source": [
    "classes_s, X_s = saade(A, n_clusters)\n",
    "classes_s, ov = overlap(real_classes, classes_s)\n",
    "print('Overlap: ' + str(ov))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Adjacency"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Overlap: 0.2563472563472564\n"
     ]
    }
   ],
   "source": [
    "classes_a,X_a = adjacency(A,n_clusters)\n",
    "classes_a, ov = overlap(real_classes, classes_a)\n",
    "print('Overlap: ' + str(ov))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
