{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Author: Francois Role <francois.role@gmail.com>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The following example also illustrates how to use the `coclust.io.data_loading`module the `coclust.visualization`module"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.9165940532895077\n",
      "MODULARITY: 0.40856088732671637723\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/frole/anaconda3/lib/python3.6/site-packages/matplotlib/cbook/deprecation.py:107: MatplotlibDeprecationWarning: Passing one of 'on', 'true', 'off', 'false' as a boolean is deprecated; use an actual boolean (True/False) instead.\n",
      "  warnings.warn(message, mplDeprecation, stacklevel=1)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn.metrics.cluster import normalized_mutual_info_score as nmi\n",
    "from coclust.io.data_loading import load_doc_term_data\n",
    "from coclust.coclustering import CoclustFuzzyMod\n",
    "from coclust.visualization import (plot_cluster_top_terms,\n",
    "                                   plot_convergence)\n",
    "\n",
    "\n",
    "# read data\n",
    "path = '../datasets/classic3_coclustFormat.mat'\n",
    "doc_term_data = load_doc_term_data(path)\n",
    "X = doc_term_data['doc_term_matrix']\n",
    "true_doc_labels = doc_term_data['doc_labels']\n",
    "\n",
    "# process\n",
    "model = CoclustFuzzyMod(n_clusters=3, random_state=19)\n",
    "model.fit(X)\n",
    "\n",
    "# evaluate\n",
    "predicted_doc_labels = model.row_labels_\n",
    "print(nmi(true_doc_labels, predicted_doc_labels))\n",
    "\n",
    "# Plot modularities\n",
    "print(\"MODULARITY: %s\" % model.modularity)\n",
    "plot_convergence(model.modularities, \"Modularities\")\n",
    "\n",
    "# Plot top terms\n",
    "n_terms = 10\n",
    "plot_cluster_top_terms(doc_term_data['doc_term_matrix'],\n",
    "                               doc_term_data['term_labels'],\n",
    "                               n_terms,\n",
    "                               model)"
   ]
  }
 ],
 "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.6.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
