{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "ceb8665c",
   "metadata": {},
   "source": [
    "### Plotting the Distribution of Molecule Diameters"
   ]
  },
  {
   "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_diameters = meta_data[\"molecule_diameters\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "483369e0",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/demiran1/.conda/envs/tda/lib/python3.8/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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\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_diameters, hist=True, kde=True, \n",
    "             bins=int(180/5), color = 'darkblue', \n",
    "             hist_kws={'edgecolor':'black'},\n",
    "             kde_kws={'linewidth': 4});\n",
    "\n",
    "plt.title('Density Plot and Histogram of Molecule Diameters'); \n",
    "plt.xlabel('Molecule Diameter'); 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:  33\n"
     ]
    }
   ],
   "source": [
    "print(\"Total number of molecules: \", len(list_diameters))\n",
    "print(\"Max value of molecule diameter: \", max(list_diameters))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5bb03a91",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of molecules with diameter greater than 20: 73\n"
     ]
    }
   ],
   "source": [
    "k = 20\n",
    "list_diameters.sort()\n",
    "count = len(list_diameters) - bisect(list_diameters, k)\n",
    "print(\"Number of molecules with diameter greater than %i: %i\" % (k, count))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d1508f1a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
