{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "ceb8665c",
   "metadata": {},
   "source": [
    "### Plotting the Distribution of Partial Charges"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "0db95816",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\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_charges = meta_data[\"charge_distribution\"]"
   ]
  },
  {
   "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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\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_charges, hist=True, kde=True, \n",
    "             bins=int(50), color = 'darkblue', \n",
    "             hist_kws={'edgecolor':'black'},\n",
    "             kde_kws={'linewidth': 4});\n",
    "\n",
    "plt.title('Density Plot and Histogram of Partial Charges'); \n",
    "plt.xlabel('Partial Charge'); plt.ylabel('Density');"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "13c319b4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Max value of partial charges:  3.26758\n"
     ]
    }
   ],
   "source": [
    "print(\"Max value of partial charges: \", max(list_charges))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d3e78043",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Min value of partial charges:  -2.41836\n"
     ]
    }
   ],
   "source": [
    "print(\"Min value of partial charges: \", min(list_charges))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "716964ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_bins = 10\n",
    "list_charges.sort()\n",
    "list_charges = np.array_split(list_charges, n_bins)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d8ae058a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[-2.41836,\n",
       " -0.5122,\n",
       " -0.05004,\n",
       " -0.01444,\n",
       " 0.01239,\n",
       " 0.02301,\n",
       " 0.03973,\n",
       " 0.07499,\n",
       " 0.19865,\n",
       " 0.32739]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# superlevel\n",
    "charge_levels = [x[0] for x in list_charges] \n",
    "charge_levels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "3f47ae8f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[-0.51226,\n",
       " -0.05015,\n",
       " -0.01444,\n",
       " 0.01239,\n",
       " 0.02301,\n",
       " 0.03973,\n",
       " 0.07499,\n",
       " 0.19863,\n",
       " 0.32736,\n",
       " 3.26758]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# sublevel\n",
    "charge_levels = [x[-1] for x in list_charges] \n",
    "charge_levels"
   ]
  }
 ],
 "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
}
