{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "ceb8665c",
   "metadata": {},
   "source": [
    "### Plotting the Distribution of Molecule Max. Node Degrees"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "0db95816",
   "metadata": {},
   "outputs": [],
   "source": [
    "from bisect import bisect\n",
    "from src.dataloader.cleves_jain import Parser_cj\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from IPython.core.pylabtools import figsize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "047f7abf",
   "metadata": {},
   "outputs": [],
   "source": [
    "path = \"../src/dataloader/cleves_jain\"\n",
    "train_set, test_set, meta_data = Parser_cj.get_preprocessed_data(path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a7689196",
   "metadata": {},
   "outputs": [],
   "source": [
    "list_degrees = meta_data[\"molecule_max_degrees\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "483369e0",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/seaborn/distributions.py:2619: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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IiIicqQouwMgssKLL76O3NxjQTtf9+6dcMcdNwbtfEREbQGTFApLubnHkJU1OWjnO3Dgu6Cdi4iorWBzDxERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETlSlN0BEBE5wYsvvo7c3GNBPWf37p1wxx03BvWcRKGESQoREYDc3GPIypoc1HMeOPBdUM9HFGrY3ENERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRI1mapIjIFBHZISK7ReSBRo6bJiJKREZZGQ8RERGFDsuSFBGJBPAigAsADAZwtYgM9nJcEoDfAlhhVSxEREQUeqysSTkdwG6l1F6lVBWA2QCmejnufwH8FUCFhbEQERFRiLEySUkHkO1WztG31RORkQAylFJfNfZEInKLiKwWkdX5+fmBj5SIiIgcx7aOsyISAeDvAH7f1LFKqVeVUqOUUqNSU1OtD46IiIhsZ2WScghAhlu5h77NJQnAUAALRWQ/gDEA5rLzLBEREQHWJimrAPQTkV4iEgPgKgBzXTuVUsVKqc5KqZ5KqZ4AlgO4RCm12sKYiIiIKERYlqQopWoA3AngWwDbAHyolNoiIo+JyCVWnZeIiIjCQ5SVT66UmgdgnmnbTB/HjrcyFiIiIgotnHGWiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOxCSFiIiIHIlJChERETkSkxQiIiJyJCYpRERE5EhMUoiIiMiRmKQQERGRIzFJISIiIkdikkJERESOZGmSIiJTRGSHiOwWkQe87P+NiGwSkfUislhEBlsZDxEREYUOy5IUEYkE8CKACwAMBnC1lyTkP0qpYUqpEQCeBvB3q+IhIiKi0GJlTcrpAHYrpfYqpaoAzAYw1f0ApVSJW7EdAGVhPERERBRCoix87nQA2W7lHABnmA8SkTsA3AsgBsB53p5IRG4BcAsAZGZmBjxQIiIich7bO84qpV5USvUB8EcAD/k45lWl1Cil1KjU1NTgBkhERES2sDJJOQQgw63cQ9/my2wAl1oYDxEREYUQK5OUVQD6iUgvEYkBcBWAue4HiEg/t+JFAHZZGA8RERGFEMv6pCilakTkTgDfAogE8LpSaouIPAZgtVJqLoA7RWQigGoAhQBmWBUPERERhRYrO85CKTUPwDzTtpluP//WyvMTERFR6LK94ywRERGRN0xSiIiIyJGYpBAREZEjMUkhIiIiR2KSQkRERI7EJIWIiIgciUkKERERORKTFCIiInIkJilERETkSExSiIiIyJGYpBAREZEjMUkhIiIiR2KSQkRERI7EJIWIiIgciUkKERERORKTFCIiInIkJilERETkSExSiIiIyJGYpBAREZEjMUkhIiIiR4qyOwCiQKqoqMG6dUeRkwPExpahU6c4REdH2h0WERG1AJMUChuHD5/AhAkfYtu24wAEwFLExkbihhuG4tRT0+wOj4iImonNPRQWTpyowsUXf6YnKA0qK2vx739vwsGDJTZFRkRELcUkhUJeTU0drrrqS6xde8Tr/urqOrzyykaUlVUHOTIiImoNJikU8mbNWo2vvtpr2JaUpAzlgoJyvP76Zihl3E5ERM7FJIVCWlVVLWbNWmPYduqpabj1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\n",
      "text/plain": [
       "<Figure size 648x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "figsize(9, 7)\n",
    "\n",
    "sns.distplot(list_degrees, hist=True, kde=True, \n",
    "             bins=12, color = 'darkblue', \n",
    "             hist_kws={'edgecolor':'black'},\n",
    "             kde_kws={'linewidth': 4});\n",
    "\n",
    "plt.title('Density Plot and Histogram of Molecule Max. Node Degrees'); \n",
    "plt.xlabel('Max. Degrees'); plt.ylabel('Density');"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "13c319b4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of molecules:  1149\n",
      "Max value of molecule diameter:  14.0\n"
     ]
    }
   ],
   "source": [
    "print(\"Total number of molecules: \", len(list_degrees))\n",
    "print(\"Max value of molecule diameter: \", max(list_degrees))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5bb03a91",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of molecules with max. degree greater than 9: 72\n"
     ]
    }
   ],
   "source": [
    "k = 9\n",
    "list_degrees.sort()\n",
    "count = len(list_degrees) - bisect(list_degrees, k)\n",
    "print(\"Number of molecules with max. degree greater than %i: %i\" % (k, count))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tda",
   "language": "python",
   "name": "tda"
  },
  "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.9.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
