{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "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\n",
    "\n",
    "#### Labelled datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "fb = np.loadtxt('datasets/facebook_combined.txt')\n",
    "facebook = simmetrize(fb)\n",
    "\n",
    "mail = np.loadtxt('datasets/email.txt')\n",
    "mail = mail[:,:2]\n",
    "\n",
    "power = nx.read_gml('datasets/power.gml', label = 'id')\n",
    "A_power = np.array(nx.adjacency_matrix(power).todense())\n",
    "pb = edge_list(A_power)\n",
    "power = pb\n",
    "\n",
    "nutella = np.loadtxt('datasets/p2p-Gnutella08.txt')\n",
    "nut = np.zeros((2*len(nutella),2))\n",
    "nut[:len(nutella)] = nutella\n",
    "nut[len(nutella):][:,0] = nutella[:,1]\n",
    "nut[len(nutella):][:,1] = nutella[:,0]\n",
    "nutella = nut\n",
    "\n",
    "wikipedia = np.loadtxt('datasets/Wiki-Vote.txt')\n",
    "wiki = np.zeros((2*len(wikipedia),2))\n",
    "wiki[:len(wikipedia)] = wikipedia\n",
    "wiki[len(wikipedia):][:,0] = wikipedia[:,1]\n",
    "wiki[len(wikipedia):][:,1] = wikipedia[:,0]\n",
    "wikipedia = wiki"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Create the adjacency matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "M = mail\n",
    "# M = facebook\n",
    "# M = power\n",
    "# M = nutella\n",
    "# M = wikipedia \n",
    "\n",
    "\n",
    "\n",
    "k1,k2,k3=np.unique(M,return_inverse=True,return_index=True)\n",
    "rows,cols=k3.reshape(M.shape).T\n",
    "A = sparse.coo_matrix((np.ones(rows.shape,int),(rows,cols)))\n",
    "A = scipy.sparse.csr_matrix(A)\n",
    "A = scipy.sparse.csr_matrix.sign(A)\n",
    "A = A.astype(float)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n = 1133\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 = 3*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\n",
    "\n",
    "#### Our method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Completion : 100.0%\n",
      "Modularity: 0.49427029941880135\n",
      "\n",
      "Number of classes:21\n"
     ]
    }
   ],
   "source": [
    "n_cycles = 12\n",
    "max_n_classes = 70\n",
    "percentage = 'yes'\n",
    "\n",
    "n_classes = 'none'\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",
    "print('\\nModularity: ' + str(mod))\n",
    "print('\\nNumber of classes:' + str(n_clusters))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Saade"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Modularity: 0.39907284777382784\n"
     ]
    }
   ],
   "source": [
    "classes_s, X_s = saade(A, n_clusters)\n",
    "mod = modularity(A.A, classes_s)\n",
    "print('\\nModularity: ' + str(mod))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Adjacency"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Modularity: 0.32542560589604197\n"
     ]
    }
   ],
   "source": [
    "classes_a,X_a = adjacency(A,n_clusters)\n",
    "mod = modularity(A.A, classes_a)\n",
    "print('\\nModularity: ' + str(mod))"
   ]
  },
  {
   "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
}
