{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd \n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>smiles</th>\n",
       "      <th>value</th>\n",
       "      <th>cluster</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>Brc1ccc(-[n+]2cc[n+](Cc3ccccc3)cc2)c2cc[nH]c12</td>\n",
       "      <td>7.717691</td>\n",
       "      <td>11</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>Brc1cccc(N2CCN(Cc3cnn4ccccc34)CC2)n1</td>\n",
       "      <td>6.748370</td>\n",
       "      <td>26</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>C#CC1=CCC(N(CCC)CCCCn2cc(-c3ccc(-c4ccccc4)cc3)...</td>\n",
       "      <td>6.490481</td>\n",
       "      <td>14</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>C#CCN(CCN1CCN(c2ccccc2)CC1)C1CCc2ccc(O)cc2C1</td>\n",
       "      <td>6.609065</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>C1=C(c2ccccc2)CCN(Cc2cnn(-c3ccccc3)c2)C1</td>\n",
       "      <td>7.473269</td>\n",
       "      <td>12</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>262</th>\n",
       "      <td>262</td>\n",
       "      <td>c1ccc2c(c1)N=C(N1CCNCC1)c1ccccc1S2</td>\n",
       "      <td>7.420216</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>263</th>\n",
       "      <td>263</td>\n",
       "      <td>c1cnc(N2CCN(CCCOc3ccc(-c4nc5ccccc5[nH]4)cc3)CC...</td>\n",
       "      <td>6.568636</td>\n",
       "      <td>35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>264</th>\n",
       "      <td>264</td>\n",
       "      <td>c1cnc(N2CCN(CCCOc3ccc(-c4nc5ccccc5o4)cc3)CC2)nc1</td>\n",
       "      <td>6.701147</td>\n",
       "      <td>35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>265</th>\n",
       "      <td>265</td>\n",
       "      <td>c1cnc(N2CCN(Cc3c[nH]c4ncccc34)CC2)nc1</td>\n",
       "      <td>5.931443</td>\n",
       "      <td>12</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>266</th>\n",
       "      <td>266</td>\n",
       "      <td>c1nc2c(s1)CCN(CCCCN1CCc3ncsc3CC1)CC2</td>\n",
       "      <td>5.199931</td>\n",
       "      <td>36</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>267 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Unnamed: 0                                             smiles     value  \\\n",
       "0             0     Brc1ccc(-[n+]2cc[n+](Cc3ccccc3)cc2)c2cc[nH]c12  7.717691   \n",
       "1             1               Brc1cccc(N2CCN(Cc3cnn4ccccc34)CC2)n1  6.748370   \n",
       "2             2  C#CC1=CCC(N(CCC)CCCCn2cc(-c3ccc(-c4ccccc4)cc3)...  6.490481   \n",
       "3             3       C#CCN(CCN1CCN(c2ccccc2)CC1)C1CCc2ccc(O)cc2C1  6.609065   \n",
       "4             4           C1=C(c2ccccc2)CCN(Cc2cnn(-c3ccccc3)c2)C1  7.473269   \n",
       "..          ...                                                ...       ...   \n",
       "262         262                 c1ccc2c(c1)N=C(N1CCNCC1)c1ccccc1S2  7.420216   \n",
       "263         263  c1cnc(N2CCN(CCCOc3ccc(-c4nc5ccccc5[nH]4)cc3)CC...  6.568636   \n",
       "264         264   c1cnc(N2CCN(CCCOc3ccc(-c4nc5ccccc5o4)cc3)CC2)nc1  6.701147   \n",
       "265         265              c1cnc(N2CCN(Cc3c[nH]c4ncccc34)CC2)nc1  5.931443   \n",
       "266         266               c1nc2c(s1)CCN(CCCCN1CCc3ncsc3CC1)CC2  5.199931   \n",
       "\n",
       "     cluster  \n",
       "0         11  \n",
       "1         26  \n",
       "2         14  \n",
       "3         32  \n",
       "4         12  \n",
       "..       ...  \n",
       "262        6  \n",
       "263       35  \n",
       "264       35  \n",
       "265       12  \n",
       "266       36  \n",
       "\n",
       "[267 rows x 4 columns]"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "drd = pd.read_csv('../../data/lo/drd2/test_1.csv')\n",
    "drd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "per_cluster_std = []\n",
    "for i in range(1, drd['cluster'].max()):\n",
    "    cluster = drd[drd['cluster'] == i]\n",
    "    std = cluster['value'].std()\n",
    "    per_cluster_std.append(std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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rVo1I8l88803111vly5dTGBgoNm7d6972ZEjR0x4eLi599573cv2799vJJnx48ffcH8+/PBDI8lMnDgx23tZWVnueUkmISHB/bpv37457uPln8tll3/21/s5bdiwwUgyU6dOzbb96tWrm7Zt23rUkpaWZipXrmzatGmTbbs9evTwWMevv/6a674ACgKnQnBLCAsLy/HukJo1a6p06dKKjY3V//zP/6hatWpasGCBQkJCvF6/pBy3IUlZWVnq1auXzpw5o8mTJ3u/Azk4evSotmzZon79+qlEiRLu5XXr1lWbNm00f/58j/bGmFzd7hkVFaV169bpyJEjXtc0f/58RUdH68EHH3QvCwkJ0YABA2742czMTC1atEhdunRRlSpV3Mujo6PVs2dPrVq1SmfPnvW6ps8//1ylSpXSE088ke29q09p3IzL13nMmzdPWVlZXn12y5Yt2r17t3r27KnTp0/r1KlTOnXqlFJTU9WqVSutXLky2zoff/xxj9fBwcEKDAzU8uXL9euvv+ZpXwArECxwS0hJSVF4eHi25Z9//rkWL16sGTNm6J577tGJEyeyXeCZ2/VLynEbkvTEE09o4cKFev/99xUfH+9efvHiRR07dsxjyszMzNU2Dx48KMkVjq4WFxfn/oLy1quvvqqtW7eqUqVKatCggUaPHp3ra0IOHjyoatWqZfvCzqnGq508eVJpaWnX3J+srCwdPnw4dzvxG3v37lXNmjUVEJA/Z367d++uJk2a6NFHH1XZsmX18MMP69NPP81VyNi9e7ck162zpUuX9pjef/99paenKzk52eMzlStX9njtdDr1yiuvaMGCBSpbtqzuvfdevfrqq+7TbkBBI1igyPvpp5+UnJysatWqZXvv3nvvVevWrdWjRw8tXrxYwcHB6tWrl9d/eW7dulWSctxGYmKi3nzzTY0bN069e/f2eG/16tWKjo72mG7my9NK3bp10759+zR58mSVL19e48ePV+3atbVgwQJb6ypo1zqacXXwCw4O1sqVK7VkyRL17t1b//3vf9W9e3e1adPmhiHx8u/Z+PHjtXjx4hynq68fySn4Dh06VD/++KPGjh2roKAgvfjii4qLi9PmzZu92WXAEgQLFHnTpk2TJLVt2/a67cLCwpSQkKAtW7bo008/zfX6U1JSNGfOHFWqVElxcXEe702ZMkWjR4/W0KFD9dxzz2X7bHx8fLYvknLlyuVqu5fvjNi1a1e293bu3KlSpUrd9K2I0dHRGjhwoObOnav9+/erZMmSGjNmjPv9a33pxsTEaO/eve6LCi/LqcarlS5dWiEhIdfcHz8/P1WqVMnLPZGqVq2qXbt2KSMjw6vPFS9ePMfB0i4fKfotPz8/tWrVShMnTtT27ds1ZswYLVu2TN98842ka/fX5QtHIyIi1Lp16xynYsWK5areqlWr6umnn9aiRYu0detWXbx4UX//+99zubeAdQgWKNKWLVumv/71r6pcubJ69ep1w/a9evVSxYoV9corr+Rq/efPn1fv3r31yy+/aNSoUR5fILNmzdKTTz6pXr16eQye9VvFixfP9kUSFBSUq21HR0erXr16+uijjzy+ALdu3apFixapffv2Hu1zc7tpZmZmtkPvZcqUUfny5T1uGQ0NDc3WTpLat2+vI0eO6LPPPnMvS0tL07vvvnvD/fH399fvf/97zZs3z+M2yePHj2vGjBlq2rSpIiIibrieqz3wwAM6deqU3njjjWzvXR2Afqtq1apKTk7Wf//7X/eyo0ePas6cOR7tfvnll2yfvTwI1uU+uxzwrg4q9evXV9WqVTVhwgT36bTfujxex/WkpaXpwoUL2WoPDw/36jZfwCrcbooiY8GCBdq5c6cuXbqk48ePa9myZVq8eLFiYmL0xRdf5OoLu1ixYhoyZIiGDx+uhQsX6v7773e/9/PPP7vHwkhJSdH27ds1e/ZsHTt2TE8//bT+/Oc/u9uuX79effr0UcmSJdWqVStNnz7dYzuNGzf2uEDxeiZOnJjtYlI/Pz89//zzGj9+vNq1a6dGjRrpkUcecd9uGhkZme25F7m53fTcuXOqWLGiHnzwQcXHxyssLExLlizRhg0bPP76rV+/vmbNmqVhw4bp7rvvVlhYmDp16qTHHntMb7zxhvr06aONGzcqOjpa06ZNy/XFsH/729/cY0IMHDhQAQEBeuedd5Senq5XX301V+u4Wp8+ffTxxx9r2LBhWr9+vZo1a6bU1FQtWbJEAwcOVOfOnXP83MMPP6znnntOXbt21ZNPPqm0tDS99dZbqlGjhntMD8k14uvKlSvVoUMHxcTE6MSJE3rzzTdVsWJF9zgTVatWVVRUlN5++22Fh4crNDRUDRs2VOXKlfX++++rXbt2ql27tvr3768KFSro559/1jfffKOIiAj9+9//vu7+/fjjj2rVqpW6deumWrVqKSAgQHPmzNHx48f18MMP31SfAXli810pQJ5dvt308hQYGGjKlStn2rRpYyZNmmTOnj2b7TPXu5UzOTnZREZGetyaGRMT416/w+EwERERpnbt2uaxxx4z69atu2FNV09X33aYk8s15jT5+/u72y1ZssQ0adLEBAcHm4iICNOpUyezffv2bOtTLm43TU9PN8OHDzfx8fEmPDzchIaGmvj4ePPmm296tEtJSTE9e/Y0UVFRRpLHbZkHDx40f/jDH0xISIgpVaqUGTJkiFm4cGGubjc1xphNmzaZtm3bmrCwMBMSEmJatmxpVq9e7dHGm9tNjXHdvjlq1ChTuXJlU6xYMVOuXDnz4IMPetzWqqtuNzXGmEWLFpk6deqYwMBAU7NmTfPPf/4z2+2mS5cuNZ07dzbly5c3gYGBpnz58qZHjx7mxx9/9FjXvHnzTK1atUxAQEC234HNmzebP/7xj6ZkyZLG6XSamJgY061bN7N06VJ3m2v9zp46dcoMGjTI3H777SY0NNRERkaahg0betzyCxQkhzHXORYIAADgBa6xAAAAliFYAAAAyxAsAACAZQgWAADAMgQLAABgGYIFAACwTIEPkJWVlaUjR44oPDzckicLAgCA/GeM0blz51S+fHn5+V37uESBB4sjR47c1Hj/AADAfocPH1bFihWv+X6BB4vLj5U+fPjwTY37X6Skpkrly7vmjxyRbvKBUQAA5LezZ8+qUqVK7u/xaynwYHH59EdERATBwt//ynxEBMECAFDo3egyBi7eBAAAliFYAAAAy/DYdDsFBEh9+16ZBwDAx/FtZienU0pKsrsKAAAsw6kQAABgGY5Y2MkYKS3NNR8SIjFgGADAx3HEwk5paVJYmGu6HDAAAPBhBAsAAGAZggUAALAMwQIAAFjGq2AxevRoORwOj+n222/Pr9oAAICP8fqukNq1a2vJkiVXVsDATgAA4P95nQoCAgJUrly5/KgFAAD4OK+vsdi9e7fKly+vKlWqqFevXjp06FB+1HVr8PeXHnzQNf32SacAAPgohzHG5LbxggULlJKSopo1a+ro0aNKTEzUzz//rK1bt17z+ezp6elKT093v778PPfk5GQemw4AgI84e/asIiMjb/j97VWwuNqZM2cUExOjiRMn6pFHHsmx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XPdzBw4c0DPPPKNmzZoVUKX287avLl68qDZt2ujAgQP67LPPtGvXLr333nuqUKFCAVde8LztqxkzZmjEiBFKSEjQjh079MEHH2jWrFl6/vnnC7jygpWamqr4+HhNmTIlV+3379+vDh06qGXLltqyZYuGDh2qRx999Jb4wvS2r1auXKk2bdpo/vz52rhxo1q2bKlOnTpp8+bN+Vyp/bztq8vOnDmjPn36qFWrVvlUWeFzM33VrVs3LV26VB988IF27dqlTz75RDVr1szHKvPIm4eQWaFBgwZm0KBB7teZmZmmfPnyZuzYsdf8zKVLl0zjxo3N+++/b/r27Ws6d+5cAJXaz9u+euutt0yVKlXMxYsXC6rEQsPbvho0aJC57777PJYNGzbMNGnSJF/rLEwkmTlz5ly3zbPPPmtq167tsax79+6mbdu2+VhZ4ZObvspJrVq1TGJiovUFFWLe9FX37t3NCy+8YBISEkx8fHy+1lUY5aavFixYYCIjI83p06cLpigLFOgRi4sXL2rjxo1q3bq1e5mfn59at26tNWvWXPNzL730ksqUKaNHHnmkIMosFG6mr7744gs1atRIgwYNUtmyZVWnTh29/PLLyszD49h9wc30VePGjbVx40b36ZJ9+/Zp/vz5at++fYHU7CvWrFnj0a+S1LZt2+v+e4VLVlaWzp07pxIlSthdSqE0depU7du3TwkJCXaXUqh98cUXuuuuu/Tqq6+qQoUKqlGjhp555hmdP3/e7tKu6aZG3rxZp06dUmZmZrbhv8uWLaudO3fm+JlVq1bpgw8+0JYtWwqgwsLjZvpq3759WrZsmXr16qX58+drz549GjhwoDIyMor0P96b6auePXvq1KlTatq0qYwxunTpkh5//PEifyrEW8eOHcuxX8+ePavz588rODjYpsoKvwkTJiglJUXdunWzu5RCZ/fu3RoxYoS+/fZbBQQU6NeQz9m3b59WrVqloKAgzZkzR6dOndLAgQN1+vRpTZ061e7yclSo7wo5d+6cevfurffee0+lSpWyu5xCLysrS2XKlNG7776r+vXrq3v37ho1apTefvttu0srdJYvX66XX35Zb775pjZt2qR//etf+uqrr/TXv/7V7tJQBMyYMUOJiYn69NNPVaZMGbvLKVQyMzPVs2dPJSYmqkaNGnaXU+hlZWXJ4XBo+vTpatCggdq3b6+JEyfqo48+KrRHLQo0KpYqVUr+/v46fvy4x/Ljx4+rXLly2drv3btXBw4cUKdOndzLsrKyJEkBAQHatWuXqlatmr9F28TbvpKk6OhoFStWTP7+/u5lcXFxOnbsmC5evKjAwMB8rdkuN9NXL774onr37q1HH31UknTHHXcoNTVVAwYM0KhRo+TnV6gzd4EpV65cjv0aERHB0YprmDlzph599FHNnj0722kkuP5g/O6777R582b3M6eysrJkjFFAQIAWLVqk++67z+YqC4/o6GhVqFDB43HlcXFxMsbop59+UvXq1W2sLmcF+r9nYGCg6tevr6VLl7qXZWVlaenSpWrUqFG29rfffrt++OEHbdmyxT394Q9/cF+hXqlSpYIsv0B521eS1KRJE+3Zs8cdviTpxx9/VHR0dJENFdLN9VVaWlq28HA5kBken+PWqFEjj36VpMWLF1+zX291n3zyifr3769PPvlEHTp0sLucQikiIiLb/+uPP/64atasqS1btqhhw4Z2l1ioNGnSREeOHFFKSop72Y8//ig/Pz9VrFjRxsquo6CvFp05c6ZxOp0mKSnJbN++3QwYMMBERUWZY8eOGWOM6d27txkxYsQ1P38r3RXibV8dOnTIhIeHm8GDB5tdu3aZL7/80pQpU8b87W9/s2sXCoy3fZWQkGDCw8PNJ598Yvbt22cWLVpkqlatarp162bXLhSIc+fOmc2bN5vNmzcbSWbixIlm8+bN5uDBg8YYY0aMGGF69+7tbr9v3z4TEhJihg8fbnbs2GGmTJli/P39zcKFC+3ahQLjbV9Nnz7dBAQEmClTppijR4+6pzNnzti1CwXG27662q10V4i3fXXu3DlTsWJF8+CDD5pt27aZFStWmOrVq5tHH33Url24oQIPFsYYM3nyZHPbbbeZwMBA06BBA7N27Vr3e82bNzd9+/a95mdvpWBhjPd9tXr1atOwYUPjdDpNlSpVzJgxY8ylS5cKuGp7eNNXGRkZZvTo0aZq1aomKCjIVKpUyQwcOND8+uuvBV94Afrmm2+MpGzT5b7p27evad68ebbP1KtXzwQGBpoqVaqYqVOnFnjddvC2r5o3b37d9kXZzfxe/datFCxupq927NhhWrdubYKDg03FihXNsGHDTFpaWsEXn0s8Nh0AAFiGK9QAAIBlCBYAAMAyBAsAAGAZggUAALAMwQIAAFiGYAEAACxDsAAAAJYhWAD5LDY2Vq+//rrdZeRKv3791KVLl0Kz7qSkJEVFRVlaR4sWLTR06NBCsx6gqCFYAHmQ05fLpEmT5HQ6NXPmTEnShg0bNGDAgJta/+jRo1WvXr08Vonf+te//uXVU2yXL18uh8OhM2fO5Gk9wK2iQJ9uChR1CQkJmjBhgubNm6f7779fklS6dGmbqypYGRkZKlasmN1lXFOJEiUK1XqAooYjFsA1tGjRQoMHD9bgwYMVGRmpUqVK6cUXX8zx6afGGD3xxBP6xz/+ocWLF7tDhXTjUyHLly9XgwYNFBoaqqioKDVp0kQHDx5UUlKSEhMT9f3338vhcMjhcCgpKUmSNHHiRN1xxx0KDQ1VpUqVNHDgQI+nH14+hfD1118rLi5OYWFhuv/++3X06FF3m8zMTA0bNkxRUVEqWbKknn322Wz7tnDhQjVt2tTdpmPHjtq7d6/7/QMHDsjhcGjWrFlq3ry5goKCNH369FytOydJSUm67bbbFBISoq5du+r06dPZ2sybN0933nmngoKCVKVKFSUmJurSpUuSpJ49e6p79+4e7TMyMlSqVCl9/PHHkrIfZZo2bZruuusuhYeHq1y5curZs6dOnDjh3r+WLVtKkooXLy6Hw6F+/frluJ5ff/1Vffr0UfHixRUSEqJ27dpp9+7dXv1MgKKAYAFcx0cffaSAgACtX79ekyZN0sSJE/X+++97tLl06ZL+9Kc/6bPPPtOKFSvUuHHjXK//0qVL6tKli5o3b67//ve/WrNmjQYMGCCHw6Hu3bvr6aefVu3atXX06FEdPXrU/aXp5+enf/zjH9q2bZs++ugjLVu2TM8++6zHutPS0jRhwgRNmzZNK1eu1KFDh/TMM8+43//73/+upKQkffjhh1q1apV++eUXzZkzx2MdqampGjZsmL777jstXbpUfn5+6tq1q7KysjzajRgxQkOGDNGOHTvUtm3bXK37auvWrdMjjzyiwYMHa8uWLWrZsqX+9re/ebT59ttv1adPHw0ZMkTbt2/XO++8o6SkJI0ZM0aS1KtXL/373//2CFlff/210tLS1LVr1xy3m5GRob/+9a/6/vvvNXfuXB04cMAdHipVqqTPP/9ckrRr1y4dPXpUkyZNynE9/fr103fffacvvvhCa9askTFG7du3V0ZGhrvNjX4mQJFg4wPQgEKtefPmJi4uzmRlZbmXPffccyYuLs6jTWBgoAkMDDQ7duzIcT0xMTHmtddey/G906dPG0lm+fLlOb6f26c+zp4925QsWdL9eurUqUaS2bNnj3vZlClTTNmyZd2vo6Ojzauvvup+nZGRYSpWrHjdpwefPHnSSDI//PCDMcaY/fv3G0nm9ddf92h3M+vu0aOHad++vcey7t27m8jISPfrVq1amZdfftmjzbRp00x0dLR7O6VKlTIff/yxx3q7d+/uft28eXMzZMiQa9axYcMGI8mcO3fOGHPlaZRXP/n2t+v58ccfjSTzn//8x/3+qVOnTHBwsPn000+NMbn7mQBFAUcsgOu455575HA43K8bNWqk3bt3KzMz072sadOmCgsL04svvug+JJ9bJUqUUL9+/dS2bVt16tRJkyZNytWh8SVLlqhVq1aqUKGCwsPD1bt3b50+fVppaWnuNiEhIapatar7dXR0tPsQf3Jyso4ePaqGDRu63w8ICNBdd93lsZ3du3erR48eqlKliiIiIhQbGytJOnTokEe7334ut+u+2o4dOzw+I7n6+7e+//57vfTSSwoLC3NPjz32mI4ePaq0tDQFBASoW7dumj59uiTXEZd58+apV69e19zuxo0b1alTJ912220KDw9X8+bNc9zHG9UeEBDgUX/JkiVVs2ZN7dixw73sej8ToKggWAB5dMcdd2jp0qX65ptv1L17d6/DxdSpU7VmzRo1btxYs2bNUo0aNbR27dprtj9w4IA6duyounXr6vPPP9fGjRs1ZcoUSdLFixfd7a6+gNLhcOTqOoff6tSpk3755Re99957WrdundatW5dtO5IUGhrq1XpvVkpKihITE7Vlyxb39MMPP2j37t0KCgqS5DodsnTpUp04cUJz585VcHCwxzUvv5Wamqq2bdsqIiJC06dP14YNG9ynbK7eRytY8TMBCjuCBXAdl79IL1u7dq2qV68uf39/j+X16tXT0qVLtXLlSnXr1s3jvHpu/O53v9PIkSO1evVq1alTRzNmzJAkBQYGehwdkVx/YWdlZenvf/+77rnnHtWoUUNHjhzxanuRkZGKjo722L9Lly5p48aN7tenT5/Wrl279MILL6hVq1aKi4vTr7/+asm6cxIXF5djf//WnXfeqV27dqlatWrZJj8/139njRs3VqVKlTRr1ixNnz5dDz300DXvUtm5c6dOnz6tcePGqVmzZrr99tuzHUEIDAyUpGw/h6trv3Tpkkf9l/uvVq1a191voKghWADXcejQIQ0bNky7du3SJ598osmTJ2vIkCE5to2Pj9eyZcu0atWqXIeL/fv3a+TIkVqzZo0OHjyoRYsWaffu3YqLi5PkuqNk//792rJli06dOqX09HRVq1ZNGRkZmjx5svbt26dp06bp7bff9nrfhgwZonHjxmnu3LnauXOnBg4c6DFWQ/HixVWyZEm9++672rNnj5YtW6Zhw4ZZsu6cPPnkk1q4cKEmTJig3bt364033tDChQs92vzlL3/Rxx9/rMTERG3btk07duzQzJkz9cILL3i069mzp95++20tXrz4uqdBbrvtNgUGBrr78osvvsg2NkVMTIwcDoe+/PJLnTx50uPC0MuqV6+uzp0767HHHtOqVav0/fff609/+pMqVKigzp0736C3gKKFYAFcR58+fXT+/Hk1aNBAgwYN0pAhQ6472NUdd9yhZcuWafXq1XrooYdueDg9JCREO3fu1AMPPKAaNWpowIABGjRokP785z9Lkh544AHdf//9atmypUqXLq1PPvlE8fHxmjhxol555RXVqVNH06dP19ixY73et6efflq9e/dW37591ahRI4WHh3vcOeHn56eZM2dq48aNqlOnjp566imNHz/eknXn5J577tF7772nSZMmKT4+XosWLcoWGNq2basvv/xSixYt0t1336177rlHr732mmJiYjza9erVS9u3b1eFChXUpEmTa26zdOnSSkpK0uzZs1WrVi2NGzdOEyZM8GhToUIFJSYmasSIESpbtqwGDx6c47qmTp2q+vXrq2PHjmrUqJGMMZo/f36hHtMDyA8Owwk+IEctWrRQvXr1fGY4bgAoDDhiAQAALEOwAAAAluFUCAAAsAxHLAAAgGUIFgAAwDIECwAAYBmCBQAAsAzBAgAAWIZgAQAALEOwAAAAliFYAAAAyxAsAACAZf4Pb2t/3wCrxscAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(per_cluster_std, bins=50)\n",
    "plt.axvline(x=0.56, color = 'r', ls='--')\n",
    "plt.title('DRD2-Lo: std of clusters')\n",
    "plt.xlabel('pKi standard deviation')\n",
    "plt.savefig('drd2_lo_noise.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>smiles</th>\n",
       "      <th>value</th>\n",
       "      <th>cluster</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>C=C(C)COc1ccccc1CN1CCC2(CC1)CCN(C(=O)c1ccncc1)CC2</td>\n",
       "      <td>5.794709</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>C=CCOC[C@H]1CC[C@@H](N2CC(NC(=O)CNc3nn(C)c4ccc...</td>\n",
       "      <td>5.300943</td>\n",
       "      <td>31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>C=CCO[C@H]1CC[C@@H](N2CC(NC(=O)CNc3n[nH]c4ccc(...</td>\n",
       "      <td>5.130710</td>\n",
       "      <td>31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>CC(=O)N1CCC(C2N[C@@H](c3nc(-c4ccccc4)c[nH]3)Cc...</td>\n",
       "      <td>5.008730</td>\n",
       "      <td>34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>CC(=O)NC1CCN(CCc2ccc(Oc3nc4ccccc4s3)cc2)CC1</td>\n",
       "      <td>5.045709</td>\n",
       "      <td>12</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>401</th>\n",
       "      <td>401</td>\n",
       "      <td>c1ccc(-c2c[nH]c([C@H]3Cc4c([nH]c5ccccc45)[C@@H...</td>\n",
       "      <td>6.419075</td>\n",
       "      <td>34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>402</th>\n",
       "      <td>402</td>\n",
       "      <td>c1ccc(-c2c[nH]c([C@H]3Cc4c([nH]c5ccccc45)[C@H]...</td>\n",
       "      <td>6.136083</td>\n",
       "      <td>34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>403</th>\n",
       "      <td>403</td>\n",
       "      <td>c1ccc(-c2ccc(-c3c[nH]c([C@H]4Cc5c([nH]c6ccccc5...</td>\n",
       "      <td>7.744727</td>\n",
       "      <td>34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>404</th>\n",
       "      <td>404</td>\n",
       "      <td>c1ccc(CCCNCCN(c2ccccc2)c2ccccc2)cc1</td>\n",
       "      <td>6.217567</td>\n",
       "      <td>11</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>405</th>\n",
       "      <td>405</td>\n",
       "      <td>c1ccc(CCNCCN(c2ccccc2)c2ccccc2)cc1</td>\n",
       "      <td>7.196901</td>\n",
       "      <td>11</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>406 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Unnamed: 0                                             smiles     value  \\\n",
       "0             0  C=C(C)COc1ccccc1CN1CCC2(CC1)CCN(C(=O)c1ccncc1)CC2  5.794709   \n",
       "1             1  C=CCOC[C@H]1CC[C@@H](N2CC(NC(=O)CNc3nn(C)c4ccc...  5.300943   \n",
       "2             2  C=CCO[C@H]1CC[C@@H](N2CC(NC(=O)CNc3n[nH]c4ccc(...  5.130710   \n",
       "3             3  CC(=O)N1CCC(C2N[C@@H](c3nc(-c4ccccc4)c[nH]3)Cc...  5.008730   \n",
       "4             4        CC(=O)NC1CCN(CCc2ccc(Oc3nc4ccccc4s3)cc2)CC1  5.045709   \n",
       "..          ...                                                ...       ...   \n",
       "401         401  c1ccc(-c2c[nH]c([C@H]3Cc4c([nH]c5ccccc45)[C@@H...  6.419075   \n",
       "402         402  c1ccc(-c2c[nH]c([C@H]3Cc4c([nH]c5ccccc45)[C@H]...  6.136083   \n",
       "403         403  c1ccc(-c2ccc(-c3c[nH]c([C@H]4Cc5c([nH]c6ccccc5...  7.744727   \n",
       "404         404                c1ccc(CCCNCCN(c2ccccc2)c2ccccc2)cc1  6.217567   \n",
       "405         405                 c1ccc(CCNCCN(c2ccccc2)c2ccccc2)cc1  7.196901   \n",
       "\n",
       "     cluster  \n",
       "0         20  \n",
       "1         31  \n",
       "2         31  \n",
       "3         34  \n",
       "4         12  \n",
       "..       ...  \n",
       "401       34  \n",
       "402       34  \n",
       "403       34  \n",
       "404       11  \n",
       "405       11  \n",
       "\n",
       "[406 rows x 4 columns]"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kcnh2 = pd.read_csv('../../data/lo/kcnh2/test_1.csv')\n",
    "kcnh2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "per_cluster_std = []\n",
    "for i in range(1, kcnh2['cluster'].max()):\n",
    "    cluster = kcnh2[kcnh2['cluster'] == i]\n",
    "    values = cluster['value'].to_list()\n",
    "    std = np.std(values)\n",
    "    per_cluster_std.append(std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jRubvLw813pJZvjw4Zc8nrVr1xpJZuTIkR6f5efnu+YbNWpkEhMTXcsTJ04s8hgLfy4HDhwwxhizYsWKS/6cjh8/biSZiRMnenx22223mbZt25ozZ8641dW1a1fTokULj/12797dnD9/3q2P4ODgEp0LwBcYpsE1IzMzUw6HQw0aNPD4LDs7W5JUvXr1UvU9YcIEnT9/XlOmTLlk2zlz5ig5OdljKvxX7sWMGDFC33//vV555RVVrnz5Fzbz8vL0r3/9S/369VPTpk1d6+vUqaP7779f69evd50bqeCKyKWuikhSjRo1tGPHDu3Zs8frmlatWqXKlSvrsccec63z8/Mr8qml4rbv3Lmzunfv7loXGBioRx99VAcPHtT333/vdU0ffPCBbDabJk6c6PHZpYZ3SqLwvpWPPvqoxFfICv3vf//T2rVrdc899+jUqVM6ceKETpw4oZMnTyouLk579uzRkSNH3LYZOnSo/Pz8PGr46quvfHIzNnAphBFcM+bPny9/f3/dcccd2r17t9tnQUFBkgrGzUujadOmeuihh7RgwQKlp6dftG3nzp3Vs2dPj+m666676HZTp07Va6+9pueff1533nmna31eXp4yMjLcprNnz5ao7uPHj+v06dNq2bKlx2cRERHKz89XWlpaifr6peeee04//fSTrr/+erVt21Zjx47Vd999V6JtDx06pDp16igwMNBtfVE1Frd9ccdT+Lm39u3bp7p16yokJMTrbUsiJiZGv/vd7zR58mTVqlVL8fHxWrRokZxO5yW33bt3r4wxeuaZZxQaGuo2FYanY8eOuW3TpEkTj35efPFFbd++XQ0aNFDnzp01adIk7d+/v2wOELgEwgiuGZGRkVq1apV+/vln9erVy+2XbFBQkOrWravt27eXuv8///nPOn/+vP7v//6vLMp1s3jxYv3pT3/SsGHDNGHCBLfP0tLSVKdOHbdpw4YNZV6DN2655Rbt27dPCxcuVJs2bfT666+rY8eOev311y2t60or7qrJr98TU/hOmtTUVI0YMUJHjhzRI488ok6dOiknJ+ei+8jPz5ckPfnkk0VecUtOTvZ46iogIMCjn3vuuUf79+/X7NmzVbduXU2dOlWtW7fWJ5984s0hA6VCGME1pXPnzlq5cqWOHTumXr166fjx467P7rrrLu3bt0+pqaml6rtZs2Z68MEHNX/+/EteHfHGhx9+qCFDhui3v/2t6wmUXwoPD/f45RMVFVWivkNDQ1W1alWPK0VSwdMZlSpVKnJYqyRCQkI0aNAgvfPOO0pLS1O7du3cnv4o7hd1o0aNlJ6e7vFLuKgai9u+uOMp/NxbzZo109GjR/W///3Pq+0Kr3b9+kmg4q7O3HTTTXrhhRe0ceNGvf3229qxY4eWLl0qqfjzVTi8VqVKlSKvuPXs2bPEw4916tTR448/rpUrV+rAgQOqWbOmXnjhhRJtC1wOwgiuObfddpveeecd7d27V3fccYfrnohx48apWrVqGjJkiDIzMz2227dvn2bNmnXRvidMmKBz587pxRdfLJNaP//8c91333265ZZb9Pbbb6tSJc//ZR0Oh9dDPoX8/Px0++2368MPP3S7FyQzM1NLlixR9+7dXUNYUskf7T158qTbcmBgoJo3b+427FD4botf/6K+8847df78ec2dO9e1Li8vT7Nnzy7RMd155536+uuv3UJlbm6uFixYoMaNGysyMrJE/fzS7373OxljinxJmzGm2O2aNWsmqeDn+Mta3nzzTbd2P/74o0c/7du3lyTXOatataokz/NVu3ZtxcbGFhuCfxm4i5OXl6esrCyPfuvWrVuioSLgcvFoL65J/fv312uvvaZHHnlEv/nNb/Tpp5+qWbNmWrJkie69915FREQoISFBbdq00dmzZ7VhwwYtW7bskt87Unh15Ne/bErj0KFD+s1vfiObzaa7775by5Ytc/u8Xbt2JbrpVZIWLlzo9sr7QqNGjdJf/vIXJScnq3v37nr88cdVuXJlzZ8/X06n0yNUlfTR3sjISMXGxqpTp04KCQnRxo0bXY+NFurUqZMkaeTIkYqLi5Ofn5/uu+8+9e3bV926ddNTTz2lgwcPKjIyUsuXL/f4ZVmcp556Su+884569+6tkSNHKiQkRG+++aYOHDigDz74oMhAdyk9evTQQw89pJdffll79uzRHXfcofz8fH3xxRfq0aOH23H90u23366GDRtq8ODBGjt2rPz8/LRw4UKFhobq8OHDrnZvvvmmXn31VfXv31/NmjXTqVOn9NprrykoKMh1f1BAQIAiIyP17rvv6vrrr1dISIjatGmjNm3aaM6cOerevbvatm2roUOHqmnTpsrMzFRqaqr++9//6ttvv73o8Z06dUr169fX3Xffraio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OAeFOA9X7zmwmUs9bwMAAOBDfFEeAACwFGEEAABYijACAAAsRRgBAACWIoxYZM6cOWrcuLEcDoe6dOmir7/+uti2sbGxstlsHlOfPn2uYMVlz5tzIEkzZ85Uy5YtFRAQoAYNGuiJJ57QmTNnrlC1vuPNeTh37pyee+45NWvWTA6HQ1FRUfr000+vYLVl7/PPP1ffvn1Vt25d2Ww2rVy58pLbpKSkqGPHjrLb7WrevLkWL17s8zp9ydtzkJ6ervvvv1/XX3+9KlWq5PZSyYrK23OwfPly9erVS6GhoQoKClJ0dLRWr159ZYr1IW/Pw/r169WtWzfVrFlTAQEBatWqlWbMmHFlii1DhBELvPvuuxozZowmTpyozZs3KyoqSnFxcTp27FiR7ZcvX6709HTXtH37dvn5+VXox6W9PQdLlizRU089pYkTJ2rnzp1644039O677+rpp5++wpWXLW/Pw4QJEzR//nzNnj1b33//vYYNG6b+/ftry5YtV7jyspObm6uoqCjNmTOnRO0PHDigPn36qEePHtq6datGjx6tIUOGVOhfRN6eA6fTqdDQUE2YMEFRUVE+ru7K8PYcfP755+rVq5dWrVqlTZs2qUePHurbt2+F/n9B8v48VKtWTSNGjNDnn3+unTt3asKECZowYULFe7GowRXXuXNnM3z4cNdyXl6eqVu3rklKSirR9jNmzDDVq1c3OTk5virR57w9B8OHDze33nqr27oxY8aYbt26+bROX/P2PNSpU8e88sorbut++9vfmgceeMCndV4pksyKFSsu2mbcuHGmdevWbuvuvfdeExcX58PKrpySnINfiomJMaNGjfJZPVbw9hwUioyMNJMnTy77gixS2vPQv39/8+CDD5Z9QT7ElZEr7OzZs9q0aZN69uzpWlepUiX17NlTqampJerjjTfe0H333adq1ar5qkyfKs056Nq1qzZt2uQawti/f79WrVqlO++884rU7AulOQ9Op1MOh8NtXUBAgNavX+/TWsuT1NRUt3MmSXFxcSX+/wdXp/z8fJ06dUohISFWl2KpLVu2aMOGDYqJibG6FK+U6g2sKL0TJ04oLy/P9fr8QmFhYdq1a9clt//666+1fft2vfHGG74q0edKcw7uv/9+nThxQt27d5cxRufPn9ewYcMq9DBNac5DXFycXnrpJd1yyy1q1qyZ1qxZo+XLlysvL+9KlFwuZGRkFHnOsrOz9fPPPysgIMCiymCladOmKScnR/fcc4/VpViifv36On78uM6fP69JkyZpyJAhVpfkFa6MVDBvvPGG2rZtq86dO1tdyhWVkpKiv/71r3r11Ve1efNmLV++XB9//LGef/55q0u7ombNmqUWLVqoVatW8vf314gRIzRo0CC374MCrjVLlizR5MmT9d5776l27dpWl2OJL774Qhs3btS8efM0c+ZMvfPOO1aX5BWujFxhtWrVkp+fnzIzM93WZ2ZmKjw8/KLb5ubmaunSpXruued8WaLPleYcPPPMM3rooYdcab9t27bKzc3Vo48+qj//+c8V8pdxac5DaGioVq5cqTNnzujkyZOqW7eunnrqKTVt2vRKlFwuhIeHF3nOgoKCuCpyDVq6dKmGDBmiZcuWeQzfXUuaNGkiqeDvxszMTE2aNEkDBw60uKqSq3h/g1dw/v7+6tSpk9asWeNal5+frzVr1ig6Ovqi2y5btkxOp1MPPvigr8v0qdKcg9OnT3sEDj8/P0mSqaBfr3Q5fxYcDofq1aun8+fP64MPPlB8fLyvyy03oqOj3c6ZJCUnJ1/ynOHq884772jQoEF65513KvyrDspSfn6+nE6n1WV4hSsjFhgzZowSExN1ww03qHPnzpo5c6Zyc3M1aNAgSVJCQoLq1aunpKQkt+3eeOMN9evXTzVr1rSi7DLl7Tno27evXnrpJXXo0EFdunTR3r179cwzz6hv376uUFIReXsevvrqKx05ckTt27fXkSNHNGnSJOXn52vcuHFWHsZlycnJ0d69e13LBw4c0NatWxUSEqKGDRtq/PjxOnLkiP72t79JkoYNG6ZXXnlF48aN0yOPPKK1a9fqvffe08cff2zVIVw2b8+BJG3dutW17fHjx7V161b5+/srMjLySpdfJrw9B0uWLFFiYqJmzZqlLl26KCMjQ1LBDd3BwcGWHENZ8PY8zJkzRw0bNlSrVq0kFTzyPG3aNI0cOdKS+kvN6sd5rlWzZ882DRs2NP7+/qZz587myy+/dH0WExNjEhMT3drv2rXLSDL/+te/rnClvuPNOTh37pyZNGmSadasmXE4HKZBgwbm8ccfNz/++OOVL7yMeXMeUlJSTEREhLHb7aZmzZrmoYceMkeOHLGg6rLz2WefGUkeU+FxJyYmmpiYGI9t2rdvb/z9/U3Tpk3NokWLrnjdZak056Co9o0aNbritZcVb89BTEzMRdtXVN6eh5dfftm0bt3aVK1a1QQFBZkOHTqYV1991eTl5VlzAKVkM6aCXuMGAABXBe4ZAQAAliKMAAAASxFGAACApQgjAADAUoQRAABgKcIIAACwFGEEAABYijACwOdSUlJks9n0008/lZu+bTabVq5cWWZ1LF68WDVq1Cg3/QAVCWEEKEOxsbEaPXq027q9e/dq0KBBql+/vux2u5o0aaKBAwdq48aNrjaNGzeWzWZzm6ZMmeLWz3fffaebb75ZDodDDRo00IsvvljqOg8ePCibzeZ6pTgu37333qsffvjBq20aN26smTNnXnY/QEXHd9MAPrRx40bddtttatOmjebPn69WrVrp1KlT+vDDD/XHP/5R69atc7V97rnnNHToUNdy9erVXfPZ2dm6/fbb1bNnT82bN0/btm3TI488oho1aujRRx+9osdklbNnz8rf39/qMooVEBBQJt8aXFb9ABUJV0aAEoqNjdWIESM0YsQIBQcHq1atWnrmmWeK/dZgY4wefvhhtWjRQl988YX69OmjZs2aqX379po4caI+/PBDt/bVq1dXeHi4a6pWrZrrs7fffltnz57VwoUL1bp1a913330aOXKkXnrppWLr/fHHH/XAAw8oNDRUAQEBatGihRYtWiTpwteNd+jQQTabTbGxsZKkb775Rr169VKtWrUUHBysmJgYbd682a1fm82m119/Xf3791fVqlXVokUL/eMf/3Brs2rVKl1//fUKCAhQjx49dPDgQbfPT548qYEDB6pevXqqWrWq2rZtq3feeafI8z169GjVqlVLcXFxJeq7KHv27NEtt9wih8OhyMhIJScne7RJS0vTPffcoxo1aigkJETx8fGuvv/1r3/J4XB4DAWNGjVKt956qyTP4ZV9+/YpPj5eYWFhCgwM1I033qh///vfbsd36NAhPfHEE66rYUX1I0lz585Vs2bN5O/vr5YtW+qtt95y+7wkPxOgXLP2q3GAiiMmJsYEBgaaUaNGmV27dpm///3vpmrVqmbBggVubUaNGmWMMWbz5s1GklmyZMkl+27UqJEJCwszISEhpn379ubFF180586dc33+0EMPmfj4eLdt1q5daySZ//3vf0X2OXz4cNO+fXvzzTffmAMHDpjk5GTzj3/8wxhjzNdff20kmX//+98mPT3dnDx50hhjzJo1a8xbb71ldu7cab7//nszePBgExYWZrKzs139SjL169c3S5YsMXv27DEjR440gYGBrj4OHz5s7Ha7GTNmjOs8hYWFGUmuLzb873//a6ZOnWq2bNli9u3bZ15++WXj5+dnvvrqK4/zPXbsWLNr1y6za9euEvX9a3l5eaZNmzbmtttuM1u3bjXr1q0zHTp0MJLMihUrjDHGnD171kRERJhHHnnEfPfdd+b77783999/v2nZsqVxOp3m/PnzJiwszLz++uuufn+9btGiRSY4ONj1+datW828efPMtm3bzA8//GAmTJhgHA6HOXTokDHGmJMnT5r69eub5557zqSnp5v09PQi+1m+fLmpUqWKmTNnjtm9e7eZPn268fPzM2vXri3xzwQo7wgjQAnFxMSYiIgIk5+f71r3pz/9yURERLi1KQwj7777rpFkNm/efMm+p0+fbj777DPz7bffmrlz55oaNWqYJ554wvV5r169zKOPPuq2zY4dO4wk8/333xfZZ9++fc2gQYOK/OzAgQNGktmyZctF68rLyzPVq1c3//znP13rJJkJEya4lnNycowk88knnxhjjBk/fryJjIx06+dPf/rTRQODMcb06dPH/PGPf3Qtx8TEmA4dOri1KU3fq1evNpUrV3b7duNPPvnELYy89dZbpmXLlm4/W6fTaQICAszq1auNMcaMGjXK3HrrrW792u12135/HSKK0rp1azN79mzXcqNGjcyMGTPc2vy6n65du5qhQ4e6tRkwYIC58847XcuX+pkA5R3DNIAXbrrpJtfldEmKjo7Wnj17lJeX59HWePGF2GPGjFFsbKzatWunYcOGafr06Zo9e7acTmepa33ssce0dOlStW/fXuPGjdOGDRsuuU1mZqaGDh2qFi1aKDg4WEFBQcrJydHhw4fd2rVr1841X61aNQUFBenYsWOSpJ07d6pLly5u7aOjo92W8/Ly9Pzzz6tt27YKCQlRYGCgVq9e7bGfTp06uS2XpO9f27lzpxo0aKC6desWu823336rvXv3qnr16goMDFRgYKBCQkJ05swZ7du3T5L0wAMPKCUlRUePHpVUMHTWp0+fYp98ycnJ0ZNPPqmIiAjVqFFDgYGB2rlzp8cxXsrOnTvVrVs3t3XdunXTzp073dZd7GcClHfcwAr4yPXXXy9J2rVrlzp06ODVtl26dNH58+d18OBBtWzZUuHh4crMzHRrU7gcHh5eZB+9e/fWoUOHtGrVKiUnJ+u2227T8OHDNW3atGL3m5iYqJMnT2rWrFlq1KiR7Ha7oqOjdfbsWbd2VapUcVu22WzKz88v8fFNnTpVs2bN0syZM9W2bVtVq1ZNo0eP9tjPL++b8aWcnBx16tRJb7/9tsdnoaGhkqQbb7xRzZo109KlS/XYY49pxYoVWrx4cbF9Pvnkk0pOTta0adPUvHlzBQQE6O677/Y4xrJyuT8TwEpcGQG88NVXX7ktf/nll2rRooX8/Pw82rZv316RkZGaPn16kb8ULvZejK1bt6pSpUqqXbu2pIJ/yX/++ec6d+6cq01ycrJatmyp6667rth+QkNDlZiYqL///e+aOXOmFixYIEmup1J+fUXnP//5j0aOHKk777xTrVu3lt1u14kTJ4rtvygRERH6+uuv3dZ9+eWXHvuJj4/Xgw8+qKioKDVt2rREj7OWpO+itklLS1N6enqx23Ts2FF79uxR7dq11bx5c7cpODjY1e6BBx7Q22+/rX/+85+qVKmS+vTpU+x+//Of/+jhhx9W//791bZtW4WHh3vcbOvv71/kVbVf1/+f//zHo+/IyMiLbgdUJIQRwAuHDx/WmDFjtHv3br3zzjuaPXu2Ro0aVWRbm82mRYsW6YcfftDNN9+sVatWaf/+/fruu+/0wgsvKD4+XpKUmpqqmTNn6ttvv9X+/fv19ttv64knntCDDz7oChr333+//P39NXjwYO3YsUPvvvuuZs2apTFjxhRb67PPPqsPP/xQe/fu1Y4dO/TRRx8pIiJCklS7dm0FBATo008/VWZmprKysiRJLVq00FtvvaWdO3fqq6++0gMPPOD1Y6bDhg3Tnj17NHbsWO3evVtLlizxuILQokULJScna8OGDdq5c6d+//vfe1z5KW3fv9azZ09df/31SkxM1LfffqsvvvhCf/7zn93aPPDAA6pVq5bi4+P1xRdf6MCBA0pJSdHIkSP13//+163d5s2b9cILL+juu++W3W4vdr8tWrTQ8uXLtXXrVn377be6//77PUJp48aN9fnnn+vIkSPFhr6xY8dq8eLFmjt3rvbs2aOXXnpJy5cv15NPPnmJswVUIFbftAJUFDExMebxxx83w4YNM0FBQea6664zTz/9tNtNj7+8gbXQ7t27TUJCgqlbt67x9/c3jRo1MgMHDnTd2Lpp0ybTpUsXExwcbBwOh4mIiDB//etfzZkzZ9z6+fbbb0337t2N3W439erVM1OmTLlovc8//7yJiIgwAQEBJiQkxMTHx5v9+/e7Pn/ttddMgwYNTKVKlUxMTIwxpuAJoBtuuME4HA7TokULs2zZMo+bLPWLGz8LBQcHm0WLFrmW//nPf5rmzZsbu91ubr75ZrNw4UK3m0xPnjxp4uPjTWBgoKldu7aZMGGCSUhIcHtiqKhzWZK+i7J7927TvXt34+/vb66//nrz6aefehxHenq6SUhIMLVq1TJ2u900bdrUDB061GRlZbn11blzZyPJ7WkWYzxvPD1w4IDp0aOHCQgIMA0aNDCvvPKKxzGlpqaadu3aGbvdbgr/Oi7qRthXX33VNG3a1FSpUsVcf/315m9/+5vb5yX5mQDlmc0YL+6yA65hsbGxat++vccbMwEAl4dhGgAAYCnCCAAAsBTDNAAAwFJcGQEAAJYijAAAAEsRRgAAgKUIIwAAwFKEEQAAYCnCCAAAsBRhBAAAWIowAgAALEUYAQAAlvp/Gc4tWVNYyz0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(per_cluster_std, bins=50)\n",
    "plt.axvline(x=0.68, color = 'r', ls='--')\n",
    "plt.title('KCNH2-Lo: std of clusters')\n",
    "plt.xlabel('pIC50 standard deviation')\n",
    "plt.savefig('kcnh2_lo_noise.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>smiles</th>\n",
       "      <th>value</th>\n",
       "      <th>cluster</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>Brc1ccc(-c2nc3ccc(Nc4ncnc5ccccc45)cc3[nH]2)cc1</td>\n",
       "      <td>6.419075</td>\n",
       "      <td>51</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>C=CC(=O)Nc1ccc(-c2ccc(NC(=O)Nc3ccc(F)cc3)cc2)cn1</td>\n",
       "      <td>8.047208</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>C=CC(=O)Nc1ccc(-c2ccc(NC(=O)Nc3cccc(C(C)C)c3)c...</td>\n",
       "      <td>8.508638</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>C=CC(=O)Nc1ccc(-c2ccc(NC(=O)Nc3cccc(Cl)c3)cc2)cn1</td>\n",
       "      <td>8.474955</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>C=CC(=O)Nc1cccc(-c2ccc(NC(=O)Nc3c(C)cccc3C)cc2)n1</td>\n",
       "      <td>6.380687</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>432</th>\n",
       "      <td>432</td>\n",
       "      <td>c1ccc2c(-c3cnn4cc(-c5ccc(N6CCNCC6)cc5)cnc34)cc...</td>\n",
       "      <td>6.666150</td>\n",
       "      <td>39</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>433</th>\n",
       "      <td>433</td>\n",
       "      <td>c1ccc2c(-c3cnn4cc(-c5ccc(N6CCOCC6)cc5)cnc34)cc...</td>\n",
       "      <td>5.273191</td>\n",
       "      <td>39</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>434</th>\n",
       "      <td>434</td>\n",
       "      <td>c1ccc2c(-c3cnn4cc(-c5ccc(OCCN6CCOCC6)cc5)cnc34...</td>\n",
       "      <td>5.616364</td>\n",
       "      <td>39</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>435</th>\n",
       "      <td>435</td>\n",
       "      <td>c1ccc2c(-c3nc4cc(-n5ccnc5)ccc4[nH]3)[nH]nc2c1</td>\n",
       "      <td>7.075721</td>\n",
       "      <td>45</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>436</th>\n",
       "      <td>436</td>\n",
       "      <td>c1ccc2c(-c3nc4cc(N5CCOCC5)ccc4[nH]3)[nH]nc2c1</td>\n",
       "      <td>6.793174</td>\n",
       "      <td>45</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>437 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Unnamed: 0                                             smiles     value  \\\n",
       "0             0     Brc1ccc(-c2nc3ccc(Nc4ncnc5ccccc45)cc3[nH]2)cc1  6.419075   \n",
       "1             1   C=CC(=O)Nc1ccc(-c2ccc(NC(=O)Nc3ccc(F)cc3)cc2)cn1  8.047208   \n",
       "2             2  C=CC(=O)Nc1ccc(-c2ccc(NC(=O)Nc3cccc(C(C)C)c3)c...  8.508638   \n",
       "3             3  C=CC(=O)Nc1ccc(-c2ccc(NC(=O)Nc3cccc(Cl)c3)cc2)cn1  8.474955   \n",
       "4             4  C=CC(=O)Nc1cccc(-c2ccc(NC(=O)Nc3c(C)cccc3C)cc2)n1  6.380687   \n",
       "..          ...                                                ...       ...   \n",
       "432         432  c1ccc2c(-c3cnn4cc(-c5ccc(N6CCNCC6)cc5)cnc34)cc...  6.666150   \n",
       "433         433  c1ccc2c(-c3cnn4cc(-c5ccc(N6CCOCC6)cc5)cnc34)cc...  5.273191   \n",
       "434         434  c1ccc2c(-c3cnn4cc(-c5ccc(OCCN6CCOCC6)cc5)cnc34...  5.616364   \n",
       "435         435      c1ccc2c(-c3nc4cc(-n5ccnc5)ccc4[nH]3)[nH]nc2c1  7.075721   \n",
       "436         436      c1ccc2c(-c3nc4cc(N5CCOCC5)ccc4[nH]3)[nH]nc2c1  6.793174   \n",
       "\n",
       "     cluster  \n",
       "0         51  \n",
       "1         32  \n",
       "2         32  \n",
       "3         32  \n",
       "4         32  \n",
       "..       ...  \n",
       "432       39  \n",
       "433       39  \n",
       "434       39  \n",
       "435       45  \n",
       "436       45  \n",
       "\n",
       "[437 rows x 4 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kdr = pd.read_csv('../../data/lo/kdr/test_1.csv')\n",
    "kdr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "per_cluster_std = []\n",
    "for i in range(1, kdr['cluster'].max()):\n",
    "    cluster = kdr[kdr['cluster'] == i]\n",
    "    std = cluster['value'].std()\n",
    "    per_cluster_std.append(std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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+PFKSkrS/PnztXPnTi1atKjY2wM3GmEEuIp7771XCxcu1N69e9W9e3dlZGQUa7sFCxZo9uzZCgsL07333nvV9n/605/k6+urN998U5JUv359pz8+Xbp0KXbNkZGR8vLy0j/+8Q8ZYxzr33//faWnpzs9olzcR3szMjJ06dIlp3UtWrSQh4eHU7e/n59fvj/Unp6eioqK0ooVK3T48GHH+l27dmnt2rVXPZ/27dsrMDBQM2bMcDrWxx9/rF27drn0yPVlHh4e6t27tz788MN8b9uV5HTdfqtBgwbavHmz0+O/q1atytd7durUKadlLy8vNW3aVMYYxz0cl98O+9tr9vvf/16enp4aO3ZsvlqMMfn2XZBffvkl37atW7eWJIZqUKrwaC9QDA8++KDee+89Pfnkk/rd736nNWvWON1IuXTpUvn7+ys7O9vxBtYNGzaoVatWWrJkSbGOcdttt2ngwIF69913tWvXLoWGhhbZ/sSJE/rb3/6Wb329evXUr18/jR49WmPHjlX37t31u9/9TikpKXr33XfVoUMHpxeuFffR3s8++0zDhg1Tnz591KhRI126dEnz5s2Tp6en/vCHPzjatWvXTp9++qnefvtt1ahRQ/Xq1VOnTp00duxYrVmzRnfddZeeeeYZXbp0yfEOju+++67Icy1fvrz+3//7fxo4cKDCw8PVt29fx6O9devW1XPPPVfk9oV544039Mknnyg8PFxDhw5VaGiojh07piVLluirr74q9MVpgwcP1tKlS9W9e3c9/PDD2rdvnz744IN8jxHfd999Cg4OVpcuXRQUFKRdu3Zp6tSpio6OdtxH1K5dO0nSyy+/rEcffVTly5dXz5491aBBA/3tb3/T6NGjdfDgQfXu3VsVKlTQgQMHtHz5cg0dOlTPP/98kef3z3/+U++++64efPBBNWjQQGfOnNF7772ngIAA3X///SW6ZsANYdlzPEApVdSjoRMmTDCSzAMPPGAuXrzoeLT38uTt7W1q1aplHnjgATNnzhxz4cKFfPu4/GhvQfbt22c8PT0LfGz0f11+lLOg6d5773W0mzp1qmnSpIkpX768CQoKMk8//bT55ZdfnPZV3Ed79+/fb5588knToEED4+3tbapUqWK6du1qPv30U6d2u3fvNnfffbfx8fExkpzOZf369aZdu3bGy8vL1K9f38yYMcNxDYtj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3uQMrquOHTua2NhYx3JOTo6pUaOGiYuLK3SbS5cumc6dO5vZs2eb/v37m169ermh0rLP1Ws9ffp0U79+fZOdne2uEm8qrl7v2NhYc8899zitGzlypOnSpcsNrfNmI8ksX768yDYvvPCCadasmdO6Rx55xERFRd3Aym4+xbnWBWnatKkZO3bs9S/oFkLPyHWUnZ2trVu3KjIy0rHOw8NDkZGR2rRpU6Hbvf766woMDNSgQYPcUeZNoSTX+r///a/CwsIUGxuroKAgNW/eXG+88YZycnLcVXaZVZLr3blzZ23dutUxlLN//36tXr1a999/v1tqvpVs2rTJ6WcjSVFRUUX+3sH1kZubqzNnzqhKlSpWl1KmlegNrCjYyZMnlZOT43g1/mVBQUHavXt3gdt89dVXev/995WcnOyGCm8eJbnW+/fv12effaZ+/fpp9erV2rt3r5555hldvHhRY8aMcUfZZVZJrvdjjz2mkydP6s4775QxRpcuXdJTTz3FMM0NkJqaWuDPJiMjQ+fPn5ePj49Fld38JkyYoLNnz+rhhx+2upQyjZ4RC505c0ZPPPGE3nvvPVWtWtXqcm56ubm5CgwM1KxZs9SuXTs98sgjevnllzVjxgyrS7spJSYm6o033tC7776rbdu2admyZfroo480btw4q0sDrosFCxZo7Nix+ve//63AwECryynT6Bm5jqpWrSpPT0+lpaU5rU9LS1NwcHC+9vv27dPBgwfVs2dPx7rc3FxJUrly5ZSSkqIGDRrc2KLLKFevtSRVr15d5cuXl6enp2NdaGioUlNTlZ2dLS8vrxtac1lWkuv917/+VU888YQGDx4sSWrRooUyMzM1dOhQvfzyy05fqIlrExwcXODPJiAggF6RG2TRokUaPHiwlixZkm+IDK7jt8F15OXlpXbt2mndunWOdbm5uVq3bp3CwsLytW/SpIl27Nih5ORkx/S73/3OcUd87dq13Vl+meLqtZakLl26aO/evY7AJ0k//vijqlevThC5ipJc73PnzuULHJeDoOErsa6rsLAwp5+NJCUkJBT6s8G1WbhwoQYOHKiFCxcqOjra6nJuDlbfQXuzWbRokbHb7SY+Pt788MMPZujQoaZSpUomNTXVGGPME088YV588cVCt+dpmuJz9VofPnzYVKhQwQwbNsykpKSYVatWmcDAQPO3v/3NqlMoU1y93mPGjDEVKlQwCxcuNPv37zeffPKJadCggXn44YetOoUy48yZM2b79u1m+/btRpJ5++23zfbt282hQ4eMMca8+OKL5oknnnC0379/v/H19TWjRo0yu3btMtOmTTOenp5mzZo1Vp1CmeHqtZ4/f74pV66cmTZtmjl27JhjOn36tFWncFMgjNwA77zzjrn99tuNl5eX6dixo9m8ebPjs/DwcNO/f/9CtyWMuMbVa71x40bTqVMnY7fbTf369c348ePNpUuX3Fx12eXK9b548aJ57bXXTIMGDYy3t7epXbu2eeaZZ8wvv/zi/sLLmM8//9xIyjddvr79+/c34eHh+bZp3bq18fLyMvXr1zdz5851e91lkavXOjw8vMj2KBmbMfSXAgAA63DPCAAAsBRhBAAAWIowAgAALEUYAQAAliKMAAAASxFGAACApQgjAADAUoQRADdcYmKibDabTp8+XWr2bbPZtGLFiutWR3x8vCpVqlRq9gOUJYQR4DqKiIjQiBEjnNbt3btXAwcOVK1atWS321WvXj317dtXSUlJjjZ169aVzWZzmt58802n/Xz33Xe666675O3trdq1a+vvf/97ies8ePCgbDabkpOTS7wPOHvkkUf0448/urRN3bp1NXny5GveD1DW8a29wA2UlJSke++9V82bN9fMmTPVpEkTnTlzRitXrtSf//xnrV+/3tH29ddf15AhQxzLFSpUcMxnZGTovvvuU2RkpGbMmKEdO3boySefVKVKlTR06FC3npNVSvs3K/v4+FyXb8i9XvsByhJ6RoBiioiI0LBhwzRs2DBVrFhRVatW1V//+tdCv4HWGKMBAwYoJCREX375paKjo9WgQQO1bt1aY8aM0cqVK53aV6hQQcHBwY7Jz8/P8dn8+fOVnZ2tOXPmqFmzZnr00Uf17LPP6u233y603l9++UX9+vVTtWrV5OPjo5CQEM2dO1eSVK9ePUlSmzZtZLPZFBERIUnasmWLunXrpqpVq6pixYoKDw/Xtm3bnPZrs9k0e/ZsPfjgg/L19VVISIj++9//OrVZvXq1GjVqJB8fH3Xt2lUHDx50+vzUqVPq27evatasKV9fX7Vo0UILFy4s8HqPGDFCVatWVVRUVLH2XZA9e/bo7rvvlre3t5o2baqEhIR8bY4cOaKHH35YlSpVUpUqVdSrVy/Hvj/55BN5e3vnGwoaPny47rnnHkn5h1f27dunXr16KSgoSP7+/urQoYM+/fRTp/M7dOiQnnvuOUdvWEH7kaTp06erQYMG8vLyUuPGjTVv3jynz4vzMwFKNWu/GgcoO8LDw42/v78ZPny42b17t/nggw+Mr6+vmTVrllOb4cOHG2OM2bZtm5FkFixYcNV916lTxwQFBZkqVaqY1q1bm7///e/m4sWLjs+feOKJfF+g+NlnnxlJ5v/+7/8K3GdsbKxp3bq12bJlizlw4IBJSEgw//3vf40xxnzzzTdGkvn000/NsWPHzKlTp4wxxqxbt87MmzfP7Nq1y/zwww9m0KBBJigoyGRkZDj2K8nUqlXLLFiwwOzZs8c8++yzxt/f37GPw4cPG7vdbkaOHOm4TkFBQUaS40vyfvrpJ/PWW2+Z7du3m3379pl//OMfxtPT03z99df5rveoUaPM7t27ze7du4u179/KyckxzZs3N/fee69JTk4269evN23atDGSzPLly40xxmRnZ5vQ0FDz5JNPmu+++8788MMP5rHHHjONGzc2WVlZ5tKlSyYoKMjMnj3bsd/frps7d66pWLGi4/Pk5GQzY8YMs2PHDvPjjz+aV155xXh7ezu+DfbUqVOmVq1a5vXXX3d882tB+1m2bJkpX768mTZtmklJSTETJ040np6e5rPPPiv2zwQo7QgjQDGFh4eb0NBQk5ub61j3l7/8xYSGhjq1uRxGFi9ebCSZbdu2XXXfEydONJ9//rn59ttvzfTp002lSpXMc8895/i8W7duZujQoU7b7Ny500gyP/zwQ4H77Nmzpxk4cGCBnx04cMBIMtu3by+yrpycHFOhQgXz4YcfOtZJMq+88opj+ezZs0aS+fjjj40xxowePdo0bdrUaT9/+ctfigwMxhgTHR1t/vznPzuWw8PDTZs2bZzalGTfa9euNeXKlTNHjx51rPv444+dwsi8efNM48aNnX62WVlZxsfHx6xdu9YYY8zw4cPNPffc47Rfu93uOO5vQ0RBmjVrZt555x3Hcp06dcykSZOc2vx2P507dzZDhgxxatOnTx9z//33O5av9jMBSjuGaQAX3HHHHY7udEkKCwvTnj17lJOTk6+tceELsUeOHKmIiAi1bNlSTz31lCZOnKh33nlHWVlZJa716aef1qJFi9S6dWu98MIL2rhx41W3SUtL05AhQxQSEqKKFSsqICBAZ8+e1eHDh53atWzZ0jHv5+engIAAHT9+XJK0a9cuderUyal9WFiY03JOTo7GjRunFi1aqEqVKvL399fatWvzHaddu3ZOy8XZ92/t2rVLtWvXVo0aNQrd5ttvv9XevXtVoUIF+fv7y9/fX1WqVNGFCxe0b98+SVK/fv2UmJion3/+WVLe0Fl0dHShT76cPXtWzz//vEJDQ1WpUiX5+/tr165d+c7xanbt2qUuXbo4revSpYt27drltK6onwlQ2nEDK3CDNGrUSJK0e/dutWnTxqVtO3XqpEuXLungwYNq3LixgoODlZaW5tTm8nJwcHCB++jRo4cOHTqk1atXKyEhQffee69iY2M1YcKEQo/bv39/nTp1SlOmTFGdOnVkt9sVFham7Oxsp3bly5d3WrbZbMrNzS32+b311luaMmWKJk+erBYtWsjPz08jRozId5z/vW/mRjp79qzatWun+fPn5/usWrVqkqQOHTqoQYMGWrRokZ5++mktX75c8fHxhe7z+eefV0JCgiZMmKCGDRvKx8dHDz30UL5zvF6u9WcCWImeEcAFX3/9tdPy5s2bFRISIk9Pz3xtW7duraZNm2rixIkF/lEo6r0YycnJ8vDwUGBgoKS8f8l/8cUXunjxoqNNQkKCGjdurMqVKxe6n2rVqql///764IMPNHnyZM2aNUuSHE+l/LZHZ8OGDXr22Wd1//33q1mzZrLb7Tp58mSh+y9IaGiovvnmG6d1mzdvznecXr166fHHH1erVq1Uv379Yj3OWpx9F7TNkSNHdOzYsUK3adu2rfbs2aPAwEA1bNjQaapYsaKjXb9+/TR//nx9+OGH8vDwUHR0dKHH3bBhgwYMGKAHH3xQLVq0UHBwcL6bbb28vArsVftt/Rs2bMi376ZNmxa5HVCWEEYAFxw+fFgjR45USkqKFi5cqHfeeUfDhw8vsK3NZtPcuXP1448/6q677tLq1au1f/9+fffddxo/frx69eolSdq0aZMmT56sb7/9Vvv379f8+fP13HPP6fHHH3cEjccee0xeXl4aNGiQdu7cqcWLF2vKlCkaOXJkobW++uqrWrlypfbu3audO3dq1apVCg0NlSQFBgbKx8dHa9asUVpamtLT0yVJISEhmjdvnnbt2qWvv/5a/fr1c/kx06eeekp79uzRqFGjlJKSogULFuTrQQgJCVFCQoI2btyoXbt26Y9//GO+np+S7vu3IiMj1ahRI/Xv31/ffvutvvzyS7388stObfr166eqVauqV69e+vLLL3XgwAElJibq2Wef1U8//eTUbtu2bRo/frweeugh2e32Qo8bEhKiZcuWKTk5Wd9++60ee+yxfKG0bt26+uKLL3T06NFCQ9+oUaMUHx+v6dOna8+ePXr77be1bNkyPf/881e5WkAZYvVNK0BZER4ebp555hnz1FNPmYCAAFO5cmXz0ksvOd30+L83sF6WkpJiYmJiTI0aNYyXl5epU6eO6du3r+PG1q1bt5pOnTqZihUrGm9vbxMaGmreeOMNc+HCBaf9fPvtt+bOO+80drvd1KxZ07z55ptF1jtu3DgTGhpqfHx8TJUqVUyvXr3M/v37HZ+/9957pnbt2sbDw8OEh4cbY/KeAGrfvr3x9vY2ISEhZsmSJflustT/3Ph5WcWKFc3cuXMdyx9++KFp2LChsdvt5q677jJz5sxxusn01KlTplevXsbf398EBgaaV155xcTExDg9MVTQtSzOvguSkpJi7rzzTuPl5WUaNWpk1qxZk+88jh07ZmJiYkzVqlWN3W439evXN0OGDDHp6elO++rYsaOR5PQ0izH5bzw9cOCA6dq1q/Hx8TG1a9c2U6dOzXdOmzZtMi1btjR2u91c/nVc0I2w7777rqlfv74pX768adSokfnXv/7l9HlxfiZAaWYzxoW77IBbWEREhFq3bp3vjZkAgGvDMA0AALAUYQQAAFiKYRoAAGApekYAAIClCCMAAMBShBEAAGApwggAALAUYQQAAFiKMAIAACxFGAEAAJYijAAAAEsRRgAAgKX+P4R0VZSPK+jEAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(per_cluster_std, bins=50)\n",
    "plt.axvline(x=0.68, color = 'r', ls='--')\n",
    "plt.title('KDR-Lo: std of clusters')\n",
    "plt.xlabel('pIC50 standard deviation')\n",
    "plt.savefig('kdr_lo_noise.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "lohi_benchmark",
   "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.10.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
