{
 "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": [
    "import os\n",
    "import numpy as np\n",
    "import pickle5 as pickle\n",
    "from tqdm import tqdm\n",
    "from bisect import bisect\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": "bc78df51-fa56-42b8-ac42-c0c977538393",
   "metadata": {},
   "outputs": [],
   "source": [
    "def extract_stats(file_path):\n",
    "    with open(file_path, 'rb') as f:\n",
    "        data = pickle.load(f)\n",
    "    unique_atoms = data[\"unique_atoms\"]\n",
    "    moleculer_diameter = data[\"molecule_diameter\"]\n",
    "    largest_degree = data[\"largest_degree\"]\n",
    "    partial_charges = data[\"partial_charges\"]\n",
    "    return unique_atoms, moleculer_diameter, largest_degree, partial_charges"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "047f7abf",
   "metadata": {},
   "outputs": [],
   "source": [
    "global_unique_atoms, global_moleculer_diameters, global_largest_degrees, global_partial_charges = [], [], [], []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "4952546b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parsing:  target_hivpr\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 75348/75348 [10:11<00:00, 123.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parsing:  target_cxcr4\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5738/5738 [00:32<00:00, 174.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parsing:  target_ampc\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2965/2965 [00:00<00:00, 3411827.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parsing:  target_akt1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 17000/17000 [00:00<00:00, 3647780.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parsing:  target_cp3a4\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 12304/12304 [00:00<00:00, 3655384.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parsing:  target_kif11\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 7110/7110 [00:00<00:00, 3636768.47it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parsing:  target_hivrt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 20075/20075 [00:00<00:00, 58167.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parsing:  target_gcr\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 15749/15749 [00:00<00:00, 3618520.61it/s]\n"
     ]
    }
   ],
   "source": [
    "path = \"../data/DUDE-Diverse_Dataset\"\n",
    "for dir in os.listdir(path):\n",
    "    print(\"Parsing: \", dir)\n",
    "    try:\n",
    "        for file in tqdm(os.listdir(os.path.join(path, dir))):\n",
    "            if file.endswith('pkl'):\n",
    "                file_path = os.path.join(path, dir, file)\n",
    "                unique_atoms, mol_diameter, largest_degree, partial_charges = extract_stats(file_path)\n",
    "                global_unique_atoms.append(unique_atoms)\n",
    "                global_moleculer_diameters.append(mol_diameter)\n",
    "                global_largest_degrees.append(largest_degree)\n",
    "                global_partial_charges.append(partial_charges)\n",
    "    except NotADirectoryError:\n",
    "        pass"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4da09caa",
   "metadata": {},
   "source": [
    "## Unique Atoms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "70014809",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['F', 'I', 'Br', 'Cl', 'C', 'N', 'S', 'H', 'P', 'Si', 'O']"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "global_unique_atoms = [j for i in global_unique_atoms for j in i]\n",
    "list(set(global_unique_atoms))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ca602b84",
   "metadata": {},
   "source": [
    "## Molecule Diameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c691f0d7",
   "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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ERHJK0peREREJK8oeREREZG8ouRFRERE8oqSFxEREckrSl5EREQkryh5ERERkbyi5EVERETyipIXERERyStKXkRERCSvKHkRERGRvKLkRURERPKKkhcRERHJK0peREREJK8oeREREZG8ouRFRERE8oqSFxEREckrSl5EREQkryh5ERERkbyi5EVERETyipIXERERyStKXkRERCSvKHkRERGRvKLkRURERPKKkhcRERHJK0peREREJK8oeREREZG8ouRFRERE8oqSFxEREckrJdkOQERkLEQijvvue4PVq/ewcOEkPvCB4ykvL852WCKSBmlteTGzS8xso5ltMrOb4pw/38zWmFm/mV0R5/xEM9tpZt9MZ5wikv8ef3wnDzywhebmwzzzTBPPPNOU7ZBEJE3SlryYWTFwG3ApsBj4gJktDlXbDlwL/CTB3fwr8Hi6YhSRwtDZ2cdPf/pqoGzz5tYsRSMi6ZbOlpczgU3Ouc3OuV7gbmB5dAXn3Fbn3DogEr7YzE4HpgEPpTFGESkA99+/OaZs+/a2LEQiIpmQzjEvM4EdUcc7gbNSudDMioCvAh8G3jZCveuB6wHmzJlzxIGKSP7as6eTRx/dkfD86tUv8LnP/WfK99fYWM8NN1w3FqGJSJrk6oDdTwMrnHM7zSxhJefc7cDtAMuWLXMZik1Ecsgjj2wnEon99W9t7QGgo6OHuXMvTvn+tm1TY69Irktn8rILmB11PMsvS8U5wJvN7NPABKDMzDqcczGDfkVkfNu5syNueVdXP729AxmORkQyIZ3JyyrgWDObj5e0XA18MJULnXMfGrxtZtcCy5S4iEg87e29Cc+1tSU+JyL5K20Ddp1z/cCNwIPABuBnzrn1Znarmb0bwMzOMLOdwJXAd8xsfbriEZHCNFLycuhQTwYjEZFMSeuYF+fcCmBFqOzmqNur8LqTRrqPHwA/SEN4IpImt912B01NB1Kuv3r1WubOvZju7n6amjqYPr2aqqrSpNf19Q1w+HB/wvOD415EpLDk6oBdEcljTU0HRjVI9rHHVtLe3su//duztLR0M2lSOZ/5zOlMn1494nXt7X0jnlfyIlKYtLeRiOSE557bQ0tLNwAHD/bwrW+tTTrgtq1t5OREyYtIYVLyIiI5Ye/ezsDxnj2d3HvvayNeM9J4F1DyIlKolLyISE5obY1NRP70p52s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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(global_moleculer_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": 7,
   "id": "13c319b4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of molecules:  40176\n",
      "Max value of molecule diameter:  32\n"
     ]
    }
   ],
   "source": [
    "print(\"Total number of molecules: \", len(global_moleculer_diameters))\n",
    "print(\"Max value of molecule diameter: \", max(global_moleculer_diameters))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5bb03a91",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of molecules with diameter greater than 20: 7108\n"
     ]
    }
   ],
   "source": [
    "k = 20\n",
    "global_moleculer_diameters.sort()\n",
    "count = len(global_moleculer_diameters) - bisect(global_moleculer_diameters, k)\n",
    "print(\"Number of molecules with diameter greater than %i: %i\" % (k, count))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1e78e44a",
   "metadata": {},
   "source": [
    "## Molecule Node Degrees"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "48483bdc",
   "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(global_largest_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": "markdown",
   "id": "da7e0f75",
   "metadata": {},
   "source": [
    "## Molecule Partial Charges"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "4e351d1a",
   "metadata": {},
   "outputs": [],
   "source": [
    "global_partial_charges = [j for i in global_partial_charges for j in i]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "11970035",
   "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(global_partial_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": 12,
   "id": "c06d1f4f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Max value of partial charges:  2.7958\n"
     ]
    }
   ],
   "source": [
    "print(\"Max value of partial charges: \", max(global_partial_charges))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "93f0c237",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Min value of partial charges:  -1.4402\n"
     ]
    }
   ],
   "source": [
    "print(\"Min value of partial charges: \", min(global_partial_charges))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "6a8de0a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_bins = 10\n",
    "global_partial_charges.sort()\n",
    "global_partial_charges = np.array_split(global_partial_charges, n_bins)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "4e590404",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[-1.4402,\n",
       " -0.3208,\n",
       " -0.1436,\n",
       " -0.0965,\n",
       " -0.0108,\n",
       " 0.0621,\n",
       " 0.0792,\n",
       " 0.1095,\n",
       " 0.1339,\n",
       " 0.1773]"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# superlevel\n",
    "charge_levels = [x[0] for x in global_partial_charges] \n",
    "charge_levels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "ed34672e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[-0.3208,\n",
       " -0.1436,\n",
       " -0.0965,\n",
       " -0.0108,\n",
       " 0.0621,\n",
       " 0.0792,\n",
       " 0.1095,\n",
       " 0.1339,\n",
       " 0.1773,\n",
       " 2.7958]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# sublevel\n",
    "charge_levels = [x[-1] for x in global_partial_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
}
