{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "from scipy.stats import spearmanr\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "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.1</th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>smiles</th>\n",
       "      <th>value</th>\n",
       "      <th>cluster</th>\n",
       "      <th>preds</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\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",
       "      <td>6.500000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>Brc1cccc(N2CCN(Cc3cnn4ccccc34)CC2)n1</td>\n",
       "      <td>6.748370</td>\n",
       "      <td>26</td>\n",
       "      <td>5.868179</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\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",
       "      <td>6.749948</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\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",
       "      <td>6.601543</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\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",
       "      <td>6.070288</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\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>262</td>\n",
       "      <td>c1ccc2c(c1)N=C(N1CCNCC1)c1ccccc1S2</td>\n",
       "      <td>7.420216</td>\n",
       "      <td>6</td>\n",
       "      <td>7.016357</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>263</th>\n",
       "      <td>263</td>\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",
       "      <td>6.612239</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>264</th>\n",
       "      <td>264</td>\n",
       "      <td>264</td>\n",
       "      <td>c1cnc(N2CCN(CCCOc3ccc(-c4nc5ccccc5o4)cc3)CC2)nc1</td>\n",
       "      <td>6.701147</td>\n",
       "      <td>35</td>\n",
       "      <td>6.246894</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>265</th>\n",
       "      <td>265</td>\n",
       "      <td>265</td>\n",
       "      <td>c1cnc(N2CCN(Cc3c[nH]c4ncccc34)CC2)nc1</td>\n",
       "      <td>5.931443</td>\n",
       "      <td>12</td>\n",
       "      <td>5.792112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>266</th>\n",
       "      <td>266</td>\n",
       "      <td>266</td>\n",
       "      <td>c1nc2c(s1)CCN(CCCCN1CCc3ncsc3CC1)CC2</td>\n",
       "      <td>5.199931</td>\n",
       "      <td>36</td>\n",
       "      <td>5.462466</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>267 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Unnamed: 0.1  Unnamed: 0  \\\n",
       "0               0           0   \n",
       "1               1           1   \n",
       "2               2           2   \n",
       "3               3           3   \n",
       "4               4           4   \n",
       "..            ...         ...   \n",
       "262           262         262   \n",
       "263           263         263   \n",
       "264           264         264   \n",
       "265           265         265   \n",
       "266           266         266   \n",
       "\n",
       "                                                smiles     value  cluster  \\\n",
       "0       Brc1ccc(-[n+]2cc[n+](Cc3ccccc3)cc2)c2cc[nH]c12  7.717691       11   \n",
       "1                 Brc1cccc(N2CCN(Cc3cnn4ccccc34)CC2)n1  6.748370       26   \n",
       "2    C#CC1=CCC(N(CCC)CCCCn2cc(-c3ccc(-c4ccccc4)cc3)...  6.490481       14   \n",
       "3         C#CCN(CCN1CCN(c2ccccc2)CC1)C1CCc2ccc(O)cc2C1  6.609065       32   \n",
       "4             C1=C(c2ccccc2)CCN(Cc2cnn(-c3ccccc3)c2)C1  7.473269       12   \n",
       "..                                                 ...       ...      ...   \n",
       "262                 c1ccc2c(c1)N=C(N1CCNCC1)c1ccccc1S2  7.420216        6   \n",
       "263  c1cnc(N2CCN(CCCOc3ccc(-c4nc5ccccc5[nH]4)cc3)CC...  6.568636       35   \n",
       "264   c1cnc(N2CCN(CCCOc3ccc(-c4nc5ccccc5o4)cc3)CC2)nc1  6.701147       35   \n",
       "265              c1cnc(N2CCN(Cc3c[nH]c4ncccc34)CC2)nc1  5.931443       12   \n",
       "266               c1nc2c(s1)CCN(CCCCN1CCc3ncsc3CC1)CC2  5.199931       36   \n",
       "\n",
       "        preds  \n",
       "0    6.500000  \n",
       "1    5.868179  \n",
       "2    6.749948  \n",
       "3    6.601543  \n",
       "4    6.070288  \n",
       "..        ...  \n",
       "262  7.016357  \n",
       "263  6.612239  \n",
       "264  6.246894  \n",
       "265  5.792112  \n",
       "266  5.462466  \n",
       "\n",
       "[267 rows x 6 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "drd = pd.read_csv('../../predictions/lo/drd2/svr_ecfp4/test_1.csv')\n",
    "drd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "drd_spearmans = []\n",
    "ps = []\n",
    "for i in range(1, drd['cluster'].max()):\n",
    "    cluster = drd[drd['cluster'] == i]\n",
    "    spearman, p = spearmanr(cluster['value'], cluster['preds'])\n",
    "    if np.isnan(spearman):\n",
    "        spearman = 0.0\n",
    "    drd_spearmans.append(spearman)\n",
    "    ps.append(p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAhYAAAHHCAYAAADjzRHEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA0MElEQVR4nO3de3yP9eP/8eeMvbfZ3httcwibU3IYoo9DYkLmkFS+FR9fzSH1EUlKWZ+Ydfii0EcSfX000kFNKZ8KOaSDUIScv4iQ82QHamx7/f7w27vedrD39hobj/vtdt10va7X9bpe1+t9bXt2Hd6XlzHGCAAAwIIyV7oDAADg6kGwAAAA1hAsAACANQQLAABgDcECAABYQ7AAAADWECwAAIA1BAsAAGANwQIAAFhDsABwTdi/f7+8vLw0Z86cK90V4KpGsMBVbc6cOfLy8nJNvr6+qlq1qqKjo/Xqq68qNTU1xzrjxo1zW6dcuXKKiIjQ8OHDdfr06Rz1IyIiXHXLlCmj4OBgRUZG6qGHHtK6dety1E9KStLLL7+sdu3aKTQ0VMHBwWrVqpXef//9Au9Xdh9Pnjzp0XgUxV/HJL9p1apVRd7W2bNnNW7cOCttXS7bt2/XuHHjtH///ivdFeCKKnulOwBcDs8995xq1qyp8+fP6+jRo1q1apVGjBihKVOmaNGiRWrcuHGOdWbMmKGAgACdOXNGK1as0LRp0/Tjjz/q22+/zVG3adOmeuKJJyRJqamp2rFjhxITEzVr1iw9/vjjmjJliqvumjVr9M9//lPdunXTs88+q7Jly+rDDz9U7969tX37dsXHxxffQBTBvHnz3ObfeustLVu2LEd5/fr1i7yts2fPusahffv2RW7vcsj+7Nq3b6+IiIgr3R3gyjHAVSwhIcFIMj/88EOOZStWrDB+fn4mPDzcnD171lUeFxdnJJkTJ0641b///vuNJLNu3Tq38vDwcNO9e/cc7Z89e9bcddddRpJ5/fXXXeU///yz2b9/v1vdrKws06FDB+NwOExaWtol9yuvPl5OQ4cONcX1K+TEiRNGkomLi7PW5r59+4wkk5CQYK3Nv0pMTDSSzJdffmm13YIcD0BJwqUQXLM6dOigMWPG6JdfftHbb799yfpt27aVJO3du7dA7fv5+WnevHmqWLGiXnzxRZn//yLhmjVrKjw83K2ul5eX7rrrLqWnp+vnn3/2cE/ytnLlSrVt21bly5dXcHCwevbsqR07duSot3PnTh04cKDI28vKytK//vUvNWzYUL6+vqpUqZIefvhh/fbbb2711q9fr+joaIWEhMjPz081a9bUwIEDJV24FyI0NFSSFB8f77rEMm7cuHy3ffr0aT3++OOKiIiQw+FQtWrV9MADD+R7uah9+/a5nhHp379/jrMO8+fPV/PmzRUYGCin06nIyEhNnTpV0oVLbvfee68k6bbbbsv1stDixYtdn0VgYKC6d++ubdu25dhuQECA9u7dq27duikwMFB9+/aVJO3evVu9evVS5cqV5evrq2rVqql3795KTk7Od1yAy41LIbim9evXT88884y++OILDR48ON+62dfOK1SoUOD2AwICdPfdd2v27Nnavn27GjZsmGfdo0ePSpJCQkIK3H5+li9frq5du6pWrVoaN26cfv/9d02bNk1t2rTRjz/+6PaHs379+oqKiiryPQ0PP/yw5syZowEDBmj48OHat2+fXnvtNW3cuFGrV69WuXLldPz4cXXu3FmhoaEaPXq0goODtX//fn300UeSpNDQUM2YMUNDhgzR3XffrXvuuUeScr1clS0tLU1t27bVjh07NHDgQDVr1kwnT57UokWLdOjQoSKP6bJly9SnTx917NhREydOlCTt2LFDq1ev1mOPPaZ27dpp+PDhevXVV/XMM8+4Lgdl/ztv3jzFxMQoOjpaEydO1NmzZzVjxgzdeuut2rhxo9tnkZGRoejoaN16662aNGmS/P39de7cOUVHRys9PV2PPvqoKleurF9//VWffvqpTp8+raCgoCLtH2DVlT5lAhSn/C6FZAsKCjI33XSTaz77MsOuXbvMiRMnzP79+82bb75p/Pz8TGhoqDlz5ozb+nldCsn2yiuvGEnmk08+ybNOUlKSCQsLM23bti3QfhXkUkjTpk1NWFiYSUpKcpVt3rzZlClTxjzwwANudSWZqKioAm0728WXQr755hsjybzzzjtu9ZYsWeJWvnDhwkt+Jp5eChk7dqyRZD766KMcy7KysowxuV8KiYqKynW/Y2JiTHh4uGv+scceM06n02RkZOTZh7wuhaSmpprg4GAzePBgt/KjR4+aoKAgt/KYmBgjyYwePdqt7saNG40kk5iYmOf2gZKCSyG45gUEBOT6dEi9evUUGhqqiIgIDRw4UHXq1NHixYvl7+/vcfuSct2GdOHyQd++fXX69GlNmzbN8x3IxZEjR7Rp0yb1799fFStWdJU3btxYt99+uz7//HO3+saYIp+tSExMVFBQkG6//XadPHnSNTVv3lwBAQH68ssvJUnBwcGSpE8//VTnz58v0jazffjhh2rSpInuvvvuHMu8vLyK3H5wcLDOnDmjZcuWebzusmXLdPr0afXp08dtXLy9vdWyZUvXuPzVkCFD3Oazz0gsXbpUZ8+eLdxOAJcJwQLXvLS0NAUGBuYo//DDD7Vs2TK9++67atWqlY4fPy4/P79CtS8p121I0qOPPqolS5bo3//+t5o0aeIqP3funI4ePeo2ZWZmFmibv/zyi6QL4ehi9evX18mTJ3XmzBlPdyVfu3fvVnJyssLCwhQaGuo2paWl6fjx45KkqKgo9erVS/Hx8QoJCVHPnj2VkJCg9PT0Qm977969atSoka1dyeGRRx7RDTfcoK5du6patWoaOHCglixZUqB1d+/eLenCPT0Xj8sXX3zhGpdsZcuWVbVq1dzKatasqZEjR+rf//63QkJCFB0drenTp3N/BUok7rHANe3QoUNKTk5WnTp1cixr166d69p8jx49FBkZqb59+2rDhg0qU6bgmXzr1q2SlOs24uPj9frrr2vChAnq16+f27LvvvtOt912m1vZvn37SuyjjFlZWQoLC9M777yT6/LsGzK9vLy0YMECrV27Vv/5z3+0dOlSDRw4UJMnT9batWtdZ3guBy8vL9dNtX91cYALCwvTpk2btHTpUi1evFiLFy9WQkKCHnjgAc2dOzffbWRlZUm6cJ9F5cqVcywvW9b917DD4cj1+Jo8ebL69++vTz75RF988YWGDx+u8ePHa+3atTmCCHAlESxwTcv+Dobo6Oh86wUEBCguLk4DBgzQBx98oN69exeo/bS0NC1cuFDVq1fP8f0O06dP17hx4zRixAg9/fTTOdZt0qRJjlPvuf1hyk32Uye7du3KsWznzp0KCQlR+fLlC9RWQdWuXVvLly9XmzZtCnRmp1WrVmrVqpVefPFFvfvuu+rbt6/mz5+vBx980OPLF7Vr13YFOE9UqFAh16dwss/4/JWPj4969OihHj16KCsrS4888ojeeOMNjRkzRnXq1Mmzz7Vr15Z0IZx06tTJ4z7+VWRkpCIjI/Xss8/qu+++U5s2bTRz5ky98MILRWoXsIlLIbhmrVy5Us8//7xq1qzpeqQvP3379lW1atVcTwVcyu+//65+/frp1KlT+uc//+n2h+f999/X8OHD1bdvX7cvz/qrChUqqFOnTm6Tr69vgbZdpUoVNW3aVHPnznX7ttCtW7fqiy++ULdu3dzq23jc9L777lNmZqaef/75HMsyMjJc/fjtt99ynCVo2rSpJLkuh2Tfx5LbN53mplevXtq8ebMWLlyYY1luZySy1a5dWzt37tSJEydcZZs3b9bq1avd6iUlJbnNlylTxvWUSnafs4PaxX2Ojo6W0+nU//zP/+R6T8lft52XlJQUZWRkuJVFRkaqTJkyRbqEBBQHzljgmrB48WLt3LlTGRkZOnbsmFauXKlly5YpPDxcixYtKtAf7HLlyumxxx7TqFGjtGTJEnXp0sW17Ndff3V9F0ZaWpq2b9+uxMREHT16VE888YQefvhhV93vv/9eDzzwgK677jp17Ngxx6WDW265RbVq1SrQfk2ZMiXHzaRlypTRM888o5dfflldu3ZV69atNWjQINfjpkFBQTm+E8LG46ZRUVF6+OGHNX78eG3atEmdO3dWuXLltHv3biUmJmrq1Kn6r//6L82dO1evv/667r77btWuXVupqamaNWuWnE6nK/D4+fmpQYMGev/993XDDTeoYsWKatSoUZ73UYwaNUoLFizQvffeq4EDB6p58+Y6deqUFi1apJkzZ7rdu/JXAwcO1JQpUxQdHa1Bgwbp+PHjmjlzpho2bKiUlBRXvQcffFCnTp1Shw4dVK1aNf3yyy+aNm2amjZt6joT1bRpU3l7e2vixIlKTk6Ww+FQhw4dFBYWphkzZqhfv35q1qyZevfurdDQUB04cECfffaZ2rRpo9deey3fsV25cqWGDRume++9VzfccIMyMjI0b948eXt7q1evXoX5uIDic2UfSgGKV/bjptmTj4+PqVy5srn99tvN1KlTTUpKSo518nuUMzk52QQFBbk9ohgeHu5q38vLyzidTtOwYUMzePDgHN/SmVufLp4K8s2Q2X3MbfL29nbVW758uWnTpo3x8/MzTqfT9OjRw2zfvj1He7LwuGm2//3f/zXNmzc3fn5+JjAw0ERGRpqnnnrKHD582BhjzI8//mj69OljatSoYRwOhwkLCzN33HGHWb9+vVs73333nWnevLnx8fEp0KOnSUlJZtiwYeb66683Pj4+plq1aiYmJsacPHnSGJP3N2++/fbbplatWsbHx8c0bdrULF26NMfjpgsWLDCdO3c2YWFhxsfHx9SoUcM8/PDD5siRI25tzZo1y9SqVct4e3vnePT0yy+/NNHR0SYoKMj4+vqa2rVrm/79+7vtd0xMjClfvnyOffv555/NwIEDTe3atY2vr6+pWLGiue2228zy5cvzHRPgSvAyJp/zhAAAAB7gHgsAAGANwQIAAFhDsAAAANYQLAAAgDUECwAAYA3BAgAAWHPZvyArKytLhw8fVmBgoJW3DgIAgOJnjFFqaqqqVq2a7/uSLnuwOHz4sKpXr365NwsAACw4ePBgvi++u+zBIvvV0QcPHpTT6bzcmwcAAIWQkpKi6tWru/6O5+WyB4vsyx9Op5NgAQBAKXOp2xi4eRMAAFhDsAAAANYQLAAAgDUECwAAYA3BAgAAWEOwAAAA1hAsAACANQQLAABgDcECAABYQ7AAAADWeBQsxo0bJy8vL7fpxhtvLK6+AQCAUsbjd4U0bNhQy5cv/7OBspf9dSMAAKCE8jgVlC1bVpUrVy6OvgAAgFLO43ssdu/erapVq6pWrVrq27evDhw4UBz9AgAApZBHZyxatmypOXPmqF69ejpy5Iji4+PVtm1bbd26Nc/3s6enpys9Pd01n5KSUrQeAwCAEsvLGGMKu/Lp06cVHh6uKVOmaNCgQbnWGTdunOLj43OUJycny+l0FnbTAFAgEaM/u2Sd/RO6X4aeoKTh2PBMSkqKgoKCLvn3u0iPmwYHB+uGG27Qnj178qwTGxur5ORk13Tw4MGibBIAAJRgRQoWaWlp2rt3r6pUqZJnHYfDIafT6TYBAICrk0fB4sknn9RXX32l/fv367vvvtPdd98tb29v9enTp7j6BwAAShGPbt48dOiQ+vTpo6SkJIWGhurWW2/V2rVrFRoaWlz9AwAApYhHwWL+/PnF1Q8AAHAV4F0hAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAa4oULCZMmCAvLy+NGDHCUncAAEBpVuhg8cMPP+iNN95Q48aNbfYHAACUYoUKFmlpaerbt69mzZqlChUq2O4TAAAopQoVLIYOHaru3burU6dOl6ybnp6ulJQUtwkAAFydynq6wvz58/Xjjz/qhx9+KFD98ePHKz4+3uOOAQBKhojRn12yzv4J3UvdtlA8PDpjcfDgQT322GN655135OvrW6B1YmNjlZyc7JoOHjxYqI4CAICSz6MzFhs2bNDx48fVrFkzV1lmZqa+/vprvfbaa0pPT5e3t7fbOg6HQw6Hw05vAQBAieZRsOjYsaO2bNniVjZgwADdeOONevrpp3OECgAAcG3xKFgEBgaqUaNGbmXly5fXddddl6McAABce/jmTQAAYI3HT4VcbNWqVRa6AQAArgacsQAAANYQLAAAgDUECwAAYA3BAgAAWEOwAAAA1hAsAACANQQLAABgDcECAABYQ7AAAADWECwAAIA1BAsAAGANwQIAAFhDsAAAANYQLAAAgDUECwAAYA3BAgAAWEOwAAAA1hAsAACANQQLAABgDcECAABYQ7AAAADWECwAAIA1BAsAAGANwQIAAFhDsAAAANYQLAAAgDUECwAAYA3BAgAAWEOwAAAA1hAsAACANQQLAABgDcECAABYQ7AAAADWECwAAIA1BAsAAGANwQIAAFhDsAAAANYQLAAAgDUECwAAYA3BAgAAWEOwAAAA1hAsAACANQQLAABgDcECAABYQ7AAAADWECwAAIA1BAsAAGANwQIAAFhDsAAAANYQLAAAgDUECwAAYA3BAgAAWEOwAAAA1hAsAACANQQLAABgDcECAABYQ7AAAADWECwAAIA1BAsAAGCNR8FixowZaty4sZxOp5xOp1q3bq3FixcXV98AAEAp41GwqFatmiZMmKANGzZo/fr16tChg3r27Klt27YVV/8AAEAp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6tWrJz8/P9WoUUPDhw93vYsmW0k/JqZPn66IiAj5+vqqZcuW+v777/Otn5iYqBtvvFG+vr6KjIzU559/7rbcGKOxY8eqSpUq8vPzU6dOnbR79+7i3AVrPBmLWbNmqW3btqpQoYIqVKigTp065ajfv3//HJ99ly5dins3isyTcZgzZ06OffT19XWrU1qPCU/GIbffiV5eXurevburTmk8Hr7++mv16NFDVatWlZeXlz7++ONLrrNq1So1a9ZMDodDderU0Zw5c3LU8fT3jsc8eVeILV26dDFNmjQxa9euNd98842pU6eO6dOnT571MzIyzJEjR9ym+Ph4ExAQYFJTU131JJmEhAS3er///vvl2KVC83QsjDEmKirKDB482G0/k5OTXcszMjJMo0aNTKdOnczGjRvN559/bkJCQkxsbGxx706heToOW7ZsMffcc49ZtGiR2bNnj1mxYoWpW7eu6dWrl1u9knxMzJ8/3/j4+Jg333zTbNu2zQwePNgEBwebY8eO5Vp/9erVxtvb27z00ktm+/bt5tlnnzXlypUzW7ZscdWZMGGCCQoKMh9//LHZvHmzufPOO03NmjVLzD7nxdOx+Pvf/26mT59uNm7caHbs2GH69+9vgoKCzKFDh1x1YmJiTJcuXdw++1OnTl2uXSoUT8chISHBOJ1Ot308evSoW53SeEx4Og5JSUluY7B161bj7e1tEhISXHVK4/Hw+eefm3/+85/mo48+MpLMwoUL863/888/G39/fzNy5Eizfft2M23aNOPt7W2WLFniquPp2BbGZQ8W27dvN5LMDz/84CpbvHix8fLyMr/++muB22natKkZOHCgW1lBBr4kKexYREVFmcceeyzP5Z9//rkpU6aM2y+YGTNmGKfTadLT06303SZbx8QHH3xgfHx8zPnz511lJfmYaNGihRk6dKhrPjMz01StWtWMHz8+1/r33Xef6d69u1tZy5YtzcMPP2yMMSYrK8tUrlzZvPzyy67lp0+fNg6Hw7z33nvFsAf2eDoWF8vIyDCBgYFm7ty5rrKYmBjTs2dP210tVp6OQ0JCggkKCsqzvdJ6TBT1eHjllVdMYGCgSUtLc5WVxuPhrwryu+ypp54yDRs2dCu7//77TXR0tGu+qGNbEJf9UsiaNWsUHBysm2++2VXWqVMnlSlTRuvWrStQGxs2bNCmTZs0aNCg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jL799lutXbtWdevWVbdu3ZSamuq2nXHjxunuu+/Wli1bNHDgQEkX/o998eLFWrJkid577z3Nnj1b3bt316FDh/TVV19p4sSJevbZZ7Vu3TpXO2XKlNGrr76qbdu2ae7cuVq5cqWeeuopt22dPXtWkyZN0rx58/T111/rwIEDevLJJ/Mcg19//VXt2rWTw+HQypUrtWHDBg0cOFAZGRmSpKlTp2ry5MmaNGmSfvrpJ0VHR+vOO+/U7t27CzROTz75pBISEiRJR44c0ZEjR3Ity01sbKwmTJigMWPGaPv27Xr33XdVqVKlXOuePn1aHTp00E033aT169dryZIlOnbsmO677z63enPnzlX58uW1bt06vfTSS3ruuee0bNkySdIPP/wgSUpISNCRI0dc88BV60onG6C0WLBggalQoYLx9fU1t9xyi4mNjTWbN292qyPJ/OMf/3Ara9mypRkyZIgxxph58+aZevXqmaysLNfy9PR04+fnZ5YuXZrrdjMzM01gYKD5z3/+47adESNGuNWLi4sz/v7+JiUlxVUWHR1tIiIi3N7oWq9ePTN+/Pg89zMxMdFcd911rvmEhAQjyXW2wRhjpk+fbipVqpRnG7GxsaZmzZrm3LlzuS6vWrWqefHFF93K/va3v5lHHnnEGFOwcVq4cKG5+FdYbmV/PWORkpJiHA6HmTVrVq79uviMxfPPP286d+7sVufgwYNGkusNoVFRUebWW2/NsS9PP/20a16SWbhwYa7bBK42nLEACqhXr146fPiwFi1apC5dumjVqlVq1qyZ5syZ41avdevWOeazz1hs3rxZe/bsUWBgoOssSMWKFfXHH3+47g84duyYBg8erLp16yooKEhOp1NpaWk6cOCAW7s333xzjj5GREQoMDDQNV+pUiU1aNBAZcqUcSs7fvy4a3758uXq2LGjrr/+egUGBqpfv35KSkrS2bNnXXX8/f1Vu3Zt13yVKlXc2rjYpk2b1LZt21zv+0hJSdHhw4dz3PDapk0bj8apMHbs2KH09HR17NixQPU3b96sL7/80tWHgIAA3XjjjZLk1o/GjRu7rXep8QGuZty8CXjA19dXt99+u26//XaNGTNGDz74oOLi4tS/f/8CrZ+WlqbmzZvrnXfeybEsNDRUkhQTE6OkpCRNnTpV4eHhcjgcat26tetSSbby5cvnaOPiP+ReXl65lmVlZUm68HjlHXfcoSFDhujFF19UxYoV9e2332rQoEE6d+6c/P3982zX5PNAmZ+fX57LCqIg41QYnvYrLS1NPXr00MSJE3Msq1Kliuu/8xtj4FrDGQugCBo0aKAzZ864la1duzbHfP369SVJzZo10+7duxUWFqY6deq4TUFBQZKk1atXa/jw4erWrZsaNmwoh8OhkydPFkv/N2zYoKysLE2ePFmtWrXSDTfcoMOHDxe53caNG+ubb77R+fPncyxzOp2qWrWqVq9e7Va+evVqNWjQQFLBxqkw6tatKz8/P61YsaJA9Zs1a6Zt27YpIiIiRz9yC3Z5KVeunDIzMwvbbaBUIVgABZCUlKQOHTro7bff1k8//aR9+/YpMTFRL730knr27OlWNzExUW+++ab+7//+T3Fxcfr+++81bNgwSVLfvn0VEhKinj176ptvvtG+ffu0atUqDR8+XIcOHZJ04Y/fvHnztGPHDq1bt059+/Yt8hmAvNSpU0fnz5/XtGnT9PPPP2vevHmaOXNmkdsdNmyYUlJS1Lt3b61fv167d+/WvHnztGvXLknSqFGjNHHiRL3//vvatWuXRo8erU2bNumxxx6TVLBxKgxfX189/fTTeuqpp/TWW29p7969Wrt2rWbPnp1r/aFDh+rUqVPq06ePfvjhB+3du1dLly7VgAEDPAoKERERWrFihY4eParffvut0P0HSgOCBVAAAQEBatmypV555RW1a9dOjRo10pgxYzR48GC99tprbnXj4+M1f/58NW7cWG+99Zbee+891/+J+/v76+uvv1aNGjV0zz33qH79+ho0aJD++OMPOZ1OSdLs2bP122+/qVmzZurXr5+GDx+usLCwYtmvJk2aaMqUKZo4caIaNWqkd955R+PHjy9yu9ddd51WrlyptLQ0RUVFqXnz5po1a5brksHw4cM1cuRIPfHEE4qMjNSSJUu0aNEi1a1bV1LBxqmwxowZoyeeeEJjx45V/fr1df/99+d5P0T2mZXMzEx17txZkZGRGjFihIKDg93uW7mUyZMna9myZapevbpuuummIvUfKOn45k3AIr5hEcC1jjMWAADAGoIFAACwhsdNAYu4sgjgWscZCwAAYA3BAgAAWEOwAAAA1hAsAACANQQLAABgDcECAABYQ7AAAADWECwAAIA1BAsAAGDN/wNpmeoR5yWq/AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(drd_spearmans, bins=50)\n",
    "plt.title('DRD2-Lo: Test clusters')\n",
    "plt.xlabel('Spearman coefficient')\n",
    "plt.savefig('drd2_rho_distribution.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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.1</th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>smiles</th>\n",
       "      <th>value</th>\n",
       "      <th>cluster</th>\n",
       "      <th>preds</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\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",
       "      <td>5.552684</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\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",
       "      <td>5.699227</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\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",
       "      <td>5.669973</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\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",
       "      <td>5.299617</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "      <td>CC(=O)NC1CCN(CCc2ccc(Oc3nc4ccccc4s3)cc2)CC1</td>\n",
       "      <td>5.045709</td>\n",
       "      <td>12</td>\n",
       "      <td>5.602379</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\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>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",
       "      <td>5.346130</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>402</th>\n",
       "      <td>402</td>\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",
       "      <td>5.346130</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>403</th>\n",
       "      <td>403</td>\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",
       "      <td>5.381324</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>404</th>\n",
       "      <td>404</td>\n",
       "      <td>404</td>\n",
       "      <td>c1ccc(CCCNCCN(c2ccccc2)c2ccccc2)cc1</td>\n",
       "      <td>6.217567</td>\n",
       "      <td>11</td>\n",
       "      <td>6.055644</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>405</th>\n",
       "      <td>405</td>\n",
       "      <td>405</td>\n",
       "      <td>c1ccc(CCNCCN(c2ccccc2)c2ccccc2)cc1</td>\n",
       "      <td>7.196901</td>\n",
       "      <td>11</td>\n",
       "      <td>6.072413</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>406 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Unnamed: 0.1  Unnamed: 0  \\\n",
       "0               0           0   \n",
       "1               1           1   \n",
       "2               2           2   \n",
       "3               3           3   \n",
       "4               4           4   \n",
       "..            ...         ...   \n",
       "401           401         401   \n",
       "402           402         402   \n",
       "403           403         403   \n",
       "404           404         404   \n",
       "405           405         405   \n",
       "\n",
       "                                                smiles     value  cluster  \\\n",
       "0    C=C(C)COc1ccccc1CN1CCC2(CC1)CCN(C(=O)c1ccncc1)CC2  5.794709       20   \n",
       "1    C=CCOC[C@H]1CC[C@@H](N2CC(NC(=O)CNc3nn(C)c4ccc...  5.300943       31   \n",
       "2    C=CCO[C@H]1CC[C@@H](N2CC(NC(=O)CNc3n[nH]c4ccc(...  5.130710       31   \n",
       "3    CC(=O)N1CCC(C2N[C@@H](c3nc(-c4ccccc4)c[nH]3)Cc...  5.008730       34   \n",
       "4          CC(=O)NC1CCN(CCc2ccc(Oc3nc4ccccc4s3)cc2)CC1  5.045709       12   \n",
       "..                                                 ...       ...      ...   \n",
       "401  c1ccc(-c2c[nH]c([C@H]3Cc4c([nH]c5ccccc45)[C@@H...  6.419075       34   \n",
       "402  c1ccc(-c2c[nH]c([C@H]3Cc4c([nH]c5ccccc45)[C@H]...  6.136083       34   \n",
       "403  c1ccc(-c2ccc(-c3c[nH]c([C@H]4Cc5c([nH]c6ccccc5...  7.744727       34   \n",
       "404                c1ccc(CCCNCCN(c2ccccc2)c2ccccc2)cc1  6.217567       11   \n",
       "405                 c1ccc(CCNCCN(c2ccccc2)c2ccccc2)cc1  7.196901       11   \n",
       "\n",
       "        preds  \n",
       "0    5.552684  \n",
       "1    5.699227  \n",
       "2    5.669973  \n",
       "3    5.299617  \n",
       "4    5.602379  \n",
       "..        ...  \n",
       "401  5.346130  \n",
       "402  5.346130  \n",
       "403  5.381324  \n",
       "404  6.055644  \n",
       "405  6.072413  \n",
       "\n",
       "[406 rows x 6 columns]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kcnh2 = pd.read_csv('../../predictions/lo/kcnh2/svr_ecfp4/test_1.csv')\n",
    "kcnh2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "kcnh2_spearmans = []\n",
    "ps = []\n",
    "for i in range(1, kcnh2['cluster'].max()):\n",
    "    cluster = kcnh2[kcnh2['cluster'] == i]\n",
    "    spearman, p = spearmanr(cluster['value'], cluster['preds'])\n",
    "    if np.isnan(spearman):\n",
    "        spearman = 0.0\n",
    "    kcnh2_spearmans.append(spearman)\n",
    "    ps.append(p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAHHCAYAAABtF1i4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA6EElEQVR4nO3deVxV1f7/8TcOHBwANRNQSQjNeaQ0tNQSQ6OS8jpUN8zUboWl1251KY20AcfMW+aUQ1lm2U29N00jlMyxNCk1M6eSElC7BopfUWH9/ujnqRODHASW4Ov5eOzHo7322nt99hLl3R7O8TDGGAEAAFhSyXYBAADg8kYYAQAAVhFGAACAVYQRAABgFWEEAABYRRgBAABWEUYAAIBVhBEAAGAVYQQAAFhFGAEAN3h4eOi5556zXQZQoRBGcFlbsGCBPDw8tHXrVpf2jIwMdezYUV5eXlq1apWzff/+/frb3/6mq6++Wl5eXvLx8VGXLl00bdo0/d///Z+zX1BQkDw8PPToo4/mGTMpKUkeHh764IMPLljHed27d1erVq2c66dOndL06dN1yy23KCAgQN7e3mrfvr1mzJihnJycizr30nR+Xi60LFiwoETGe+mll7Rs2bISOVZZOHz4sJ577jklJyfbLgUoU1VsFwBcajIzM3XLLbfom2++0dKlS9WrVy9J0ooVK9SvXz85HA5FR0erVatWOnPmjNavX68nnnhCu3bt0uzZs12ONWfOHMXGxqp+/folWuOBAwf06KOPqkePHho1apR8fHy0evVqPfLII9q8ebPefPPNEh2vpLzyyis6efKkc33lypV69913NXXqVNWtW9fZ3rlz5xIZ76WXXtJf/vIXRUVFlcjxStvhw4c1duxYBQUFqV27drbLAcoMYQT4gxMnTigiIkLJycn68MMP1bt3b0nSwYMHNXDgQDVq1Ehr1qxRQECAc5+YmBjt27dPK1ascDlWy5YttWfPHo0fP17/+te/SrROf39/7dixQy1btnS2/e1vf9MDDzyg+fPna8yYMWrcuHGJjlkS/hwK0tLS9O677yoqKkpBQUFWarocZGVlqUaNGrbLAArEbRrg/zt58qR69eqlr776Sv/+978VGRnp3DZx4kSdPHlSc+fOdQki5zVu3FgjRoxwaQsKClJ0dLTmzJmjw4cPl2itdevWdQki5915552SpN27d5fYWNu3b1fv3r3l4+OjmjVrqkePHtq8eXOefvv379f+/ftLZMy3335boaGhqlatmurUqaOBAwcqJSXFpc/evXvVt29f+fv7y8vLSw0bNtTAgQOVkZEh6bdnO7KysvTmm286b//cf//9hY57+vRpPffcc7rmmmvk5eWlgIAA3XXXXYWe1/33359vkHruuefk4eHh0paQkKAbbrhBtWrVUs2aNdW0aVM9/fTTkn67fXfddddJkgYPHpzvLastW7aoV69e8vX1VfXq1dWtWzdt2LAh33G//fZb3XPPPapdu7ZuuOEGSb+Fv8GDB6thw4ZyOBwKCAhQnz599MMPPxQ6L0Bp48oIoN/+z7F379768ssv9cEHH+i2225z2f7f//5XV199tdu3D5555hm99dZbRb46kpGRoWPHjuVpP3v2bJHGS0tLkySXWx4XY9euXbrxxhvl4+OjJ598UlWrVtWsWbPUvXt3ffbZZ+rUqZOzb48ePSTpon+xvfjiixozZoz69++voUOH6ujRo3r11VfVtWtXbd++XbVq1dKZM2cUERGh7OxsPfroo/L399fPP/+sjz76SL/++qt8fX21cOFCDR06VB07dtSDDz4oSQoJCSlw3JycHN12221KTEzUwIEDNWLECJ04cUIJCQnauXNnofsWxa5du3TbbbepTZs2GjdunBwOh/bt2+cME82bN9e4ceP07LPP6sEHH9SNN94o6fdbVmvWrFHv3r0VGhqquLg4VapUSfPnz9fNN9+szz//XB07dnQZr1+/fmrSpIleeuklGWMkSX379tWuXbv06KOPKigoSEeOHFFCQoIOHTrElSnYZYDL2Pz5840k06hRI1O1alWzbNmyPH0yMjKMJNOnT58iH7dRo0YmMjLSGGPM4MGDjZeXlzl8+LAxxpi1a9caSWbJkiV56ihsadmyZaFjZmdnmxYtWpjg4GBz9uzZIp/7l19+WWCfqKgo4+npafbv3+9sO3z4sPH29jZdu3bNc86NGjW64Lh/NGnSJCPJHDx40BhjzA8//GAqV65sXnzxRZd+O3bsMFWqVHG2b9++Pc8c5qdGjRpm0KBBRapl3rx5RpJ5+eWX82zLzc11/rckExcX51wfNGhQvucdFxdn/vhP7NSpU40kc/To0QJr+PLLL40kM3/+/DzjN2nSxERERLjUcurUKRMcHGx69uyZZ9y7777b5RjHjx83ksykSZMKHB+whds0gKT09HR5eXkpMDAwz7bMzExJkre3d7GOPXr0aJ07d07jx4+/YN/p06crISEhz9KmTZsL7jt8+HB9++23eu2111SlysVf9MzJydEnn3yiqKgoXX311c72gIAA3XPPPVq/fr1zbqTfrohc7FWRDz/8ULm5uerfv7+OHTvmXPz9/dWkSROtXbtWkuTr6ytJWr16tU6dOnVRY57373//W3Xr1s33Dag/324pjlq1akmSli9frtzcXLf2TU5O1t69e3XPPffol19+cc5LVlaWevTooXXr1uU55kMPPeSyXq1aNXl6eiopKUnHjx+/qHMBShphBJA0a9YseXp6qlevXtqzZ4/LNh8fH0m/PdxaHFdffbXuu+8+zZ49W6mpqYX27dixo8LDw/MstWvXLnS/SZMmac6cOXr++ed16623OttzcnKUlpbmspw5c6ZIdR89elSnTp1S06ZN82xr3ry5cnNz8zzHcbH27t0rY4yaNGmiK6+80mXZvXu3jhw5IkkKDg7WqFGj9MYbb6hu3bqKiIjQ9OnTnc+LFMf+/fvVtGnTEgly+RkwYIC6dOmioUOHys/PTwMHDtT7779fpGCyd+9eSdKgQYPyzMsbb7yh7OzsPOceHBzssu5wODRhwgR9/PHH8vPzU9euXTVx4kTnrT3AJp4ZASS1aNFCK1euVI8ePdSzZ09t2LDBeZXEx8dH9evX186dO4t9/GeeeUYLFy7UhAkTSvw10wULFuipp57SQw89pNGjR7tsS0lJyfNLae3aterevXuJ1lBScnNz5eHhoY8//liVK1fOs71mzZrO/54yZYruv/9+LV++XJ988okee+wxxcfHa/PmzWrYsGGZ1VzQVZM/f95LtWrVtG7dOq1du1YrVqzQqlWr9N577+nmm2/WJ598ku/5nnc+sEyaNKnAV37/ODfnx/uzkSNH6vbbb9eyZcu0evVqjRkzRvHx8VqzZo3at29f2GkCpYowAvx/HTt21LJlyxQZGamePXvq888/15VXXilJuu222zR79mxt2rRJYWFhbh87JCREf/3rXzVr1iyXhz4v1vLlyzV06FDdddddmj59ep7t/v7+SkhIcGlr27ZtkY595ZVXqnr16nmuFEnSd999p0qVKuV7W+tihISEyBij4OBgXXPNNRfs37p1a7Vu3VqjR4/W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unSxXd5lZ/fu3WrRooWWLl2q66+/XrVr19aBAwfytJ0+fVrGGNWqVeuCx8zJydHRo0dVt25dValSct8/6uHhoaVLlxY5FAHlFd/aC5Syvn376syZM3rzzTd19dVXKz09XYmJifrll19sl6azZ8+qatWqtssoU/v375ck9enTRx4eHgW2ORyOIh+zcuXKfMs1cDGsfhg9UMEdP37cSDJJSUmF9pNkXn/9ddOrVy/j5eVlgoODzZIlS1z6HDp0yPTr18/4+vqa2rVrmzvuuMMcPHjQuf2LL74w4eHh5oorrjA+Pj6ma9euZtu2bfmOc/vtt5vq1aubuLg4ExcXZ9q2bWvmzp1rAgMDTY0aNczDDz9szp07ZyZMmGD8/PzMlVdemefL0qZMmWJatWplqlevbho2bGgefvhhly8BnD9/vvH19TWrVq0yzZo1MzVq1DARERHm8OHDhc7Fzp07TWRkpPH29jY1a9Y0N9xwg9m3b58xxpicnBwzduxY06BBA+Pp6Wnatm1rPv744yLPU1xcXL7fFfTnNmPyft9NTk6OmTBhggkJCTGenp4mMDDQOScHDx40ksz27dud/Xfs2GF69eplatSoYerVq2f++te/mqNHjzq3d+vWzTz66KPmiSeeMLVr1zZ+fn4u31v05+82atSoUaHzBpRnPDMClKKaNWuqZs2aWrZsmbKzswvtO2bMGPXt21dff/217r33Xg0cOFC7d++W9NsVjIiICHl7e+vzzz/Xhg0bVLNmTfXq1UtnzpyRJJ04cUKDBg3S+vXrtXnzZjVp0kS33nqrTpw44TLOc889pzvvvFM7duzQAw88IOm3KwMff/yxVq1apXfffVdz585VZGSkfvrpJ3322WeaMGGCRo8erS1btjiPU6lSJf3rX//Srl279Oabb2rNmjV68sknXcY6deqUJk+erIULF2rdunU6dOiQ/vGPfxQ4Bz///LO6du0qh8OhNWvWaNu2bXrggQd07tw5SdK0adM0ZcoUTZ48Wd98840iIiJ0xx13aO/evUWap3/84x+aP3++JCk1NVWpqan5tuUnNjZW48eP15gxY/Ttt99q0aJF8vPzy7fvr7/+qptvvlnt27fX1q1btWrVKqWnp6t///4u/d58803VqFFDW7Zs0cSJEzVu3DglJCRIkr788ktJ0vz585WamupcByok22kIqOg++OAD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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(kcnh2_spearmans, bins=50)\n",
    "plt.title('KCNH2-Lo: Test clusters')\n",
    "plt.xlabel('Spearman coefficient')\n",
    "plt.savefig('kcnh2_rho_distribution.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",
       "      <th>preds</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",
       "      <td>6.044301</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",
       "      <td>6.586384</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",
       "      <td>6.730017</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",
       "      <td>6.272653</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",
       "      <td>6.489970</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\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",
       "      <td>6.387982</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",
       "      <td>6.440312</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",
       "      <td>6.742176</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",
       "      <td>6.260894</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",
       "      <td>6.130262</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>437 rows × 5 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     preds  \n",
       "0         51  6.044301  \n",
       "1         32  6.586384  \n",
       "2         32  6.730017  \n",
       "3         32  6.272653  \n",
       "4         32  6.489970  \n",
       "..       ...       ...  \n",
       "432       39  6.387982  \n",
       "433       39  6.440312  \n",
       "434       39  6.742176  \n",
       "435       45  6.260894  \n",
       "436       45  6.130262  \n",
       "\n",
       "[437 rows x 5 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kdr = pd.read_csv('../../predictions/lo/kdr/chemprop/test_1.csv')\n",
    "kdr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "kdr_spearmans = []\n",
    "ps = []\n",
    "for i in range(1, kdr['cluster'].max()):\n",
    "    cluster = kdr[kdr['cluster'] == i]\n",
    "    spearman, p = spearmanr(cluster['value'], cluster['preds'])\n",
    "    if np.isnan(spearman):\n",
    "        spearman = 0.0\n",
    "    kdr_spearmans.append(spearman)\n",
    "    ps.append(p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0, 'Spearman coefficient')"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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kydPauPGjXr88cdVt25dh2XF9XRP5cqVtWfPHh04cMDpdZctWyYfHx9169bNYVzatm0rT09PbdiwwaG+fv36Cg8Pz7F/SVq1alWOj7yA0oIwAhTCvHnz5ObmpoiICO3fv79Q20hPT5ckeXl5ObS7u7srLi5OcXFxWrRokZo0aaITJ0443KiYnp6u5ORk+3Ty5MkC7/fw4cOSpKCgIId2Nzc3NWjQwL68OB04cEBr1661h6xrU1hYmCTpxIkTkq7erHv77berR48eql27th5//HH7o9KFce0emxv5qPPkyZN17tw53X777WrRooXGjh2rH374oUDrHjhwQKmpqfL19c0xNunp6fZxuaZ+/fo5tvHwww+rU6dOGjx4sPz8/PTII4/oo48+IpigVOGeEaAQmjZtqtWrV6tr167q1q2bNm3a5PRVkt27d0uSAgMDHdpdXV3tf6QlKTw8XI0bN9bQoUP1ySefSJKmT5+umJgYe01AQECJ/t6N7OxsdevWTePGjct1+e233y5J8vX1VWJiotatW6c1a9ZozZo1WrRokaKiovTuu+/ezC7nKSsry2G+c+fOOnjwoFatWqXPP/9c77zzjmbOnKm5c+dq8ODB+W4rOztbvr6+eT6yXb16dYf53J6c8fDw0MaNG7VhwwZ99tlnWrt2rT788EPde++9+vzzz+Xq6urkEQI3H2EEKKR27dpp5cqVioyMVLdu3fT111/n+OORn2s3M/75svuf1ahRQ//4xz8UExOjLVu2qEOHDoqKitJdd91lr3Hm8c6AgABJV2+GbNCggb390qVLOnTokEMQKi4NGzZUenp6gbbt5uamXr16qVevXsrOztZTTz2lefPmafz48QoMDHTq45Vrx3ct+DmjSpUqOZ4uunTpko4fP56jtmrVqho4cKAGDhyo9PR0de7cWZMmTbKHkbz63LBhQ33xxRfq1KlTkR7RLVeunLp27aquXbvq1Vdf1f/93//pn//8pzZs2HBDfp5AceNjGqAIunbtqg8++EBJSUmKiIhQWlpagdZbsmSJ3nnnHYWEhKhr167XrX/66adVsWJFTZ06VdLVP7JhYWH2qVOnTgXuc1hYmNzc3PT666/LGGNvX7BggVJTUx0eUS6uR3sfeughJSQkaN26dTmWnTt3TleuXJEknT592mFZuXLl1LJlS0myf2NtpUqV7OtdT/Xq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IiJCly5dkiSdP39e/fv31zfffKMtW7aoUaNGuu+++3T+/HmH/UyaNEkPPPCAdu3apccff1zS1SsDa9as0dq1a/XBBx9owYIFioyM1C+//KKvvvpK06ZN04svvqitW7fat1OuXDm9/vrr2rNnj9599119+eWXGjdunMO+Lly4oOnTp+u9997Txo0bdeTIET377LN5jsGvv/6qzp07y2az6csvv9SOHTv0+OOP68qVK5KkWbNmacaMGZo+fbp++OEHhYeH6/7779eBAwcKNE7PPvusFi1aJEk6fvy4jh8/nmtbbqKjozV16lSNHz9ee/fu1ZIlS+Tn55dr7blz53TvvfeqdevW2r59u9auXauUlBQ99NBDDnXvvvuuKlWqpK1bt+pf//qXJk+erLi4OEnStm3bJEmLFi3S8ePH7fNAmWR1GgLKuuXLl5sqVaoYd3d307FjRxMdHW2+//57hxpJ5sknn3Roa9++vRk2bJgxxpj33nvPBAUFmezsbPvyzMxM4+HhYdatW5frfrOysoyXl5f573//67Cf0aNHO9RNnDjRVKxY0aSlpdnbwsPDTb169RzeShwUFGRiY2PzPM5ly5aZ2267zT6/aNEiI8l+VcMYY2bPnm38/Pzy3EZ0dLSpX7++uXTpUq7La9asaV5++WWHtjvvvNM89dRTxpiCjdOKFSvMn3/15db2xysjaWlpxmazmbfffjvXfv35ysiUKVNM9+7dHWqOHj1qJNnfchsaGmruuuuuHMfy3HPP2eclmRUrVuS6T6As4coIcIM9+OCDOnbsmD755BNFREQoPj5ebdq00eLFix3qQkJCcsxfuzLy/fffKykpSV5eXvarLVWrVtXFixft9zukpKRoyJAhatSokXx8fOTt7a309HQdOXLEYbt33HFHjj7Wq1dPXl5e9nk/Pz81bdpU5cqVc2g7ceKEff6LL75Q165dVatWLXl5eemxxx7T6dOndeHCBXtNxYoV1bBhQ/t8jRo1HLbxZ4mJibr77rtzvY8lLS1Nx44dy3HTb6dOnZwap8LYt2+fMjMz1bVr1wLVf//999qwYYO9D56enmrcuLEkOfSjZcuWDutdb3yAsoobWIGbwN3dXd26dVO3bt00fvx4DR48WBMnTtSAAQMKtH56erratm2r999/P8ey6tWrS5L69++v06dPa9asWQoICJDNZlNISIj9Y5xrKlWqlGMbf/7j7+Likmtbdna2pKuPsvbs2VPDhg3Tyy+/rKpVq+qbb77RoEGDdOnSJVWsWDHP7Zp8HuDz8PDIc1lBFGScCsPZfqWnp6tXr16aNm1ajmU1atSw/+/8xhi4lXBlBLBA06ZNlZGR4dC2ZcuWHPNNmjSRJLVp00YHDhyQr6+vAgMDHSYfHx9J0qZNmzRy5Ejdd999atasmWw2m06dOnVD+r9jxw5lZ2drxowZ6tChg26//XYdO3asyNtt2bKlvv76a12+fDnHMm9vb9WsWVObNm1yaN+0aZOaNm0qqWDjVBiNGjWSh4eH1q9fX6D6Nm3aaM+ePapXr16OfuQWBvNSoUIFZWVlFbbbQKlBGAFuoNOnT+vee+/Vf/7zH/3www86dOiQli1bpn/961/q3bu3Q+2yZcu0cOFC/e9//9PEiRP17bffasSIEZKkRx99VNWqVVPv3r319ddf69ChQ4qPj9fIkSP1yy+/SLr6B/O9997Tvn37tHXrVj366KNFvtKQl8DAQF2+fFlvvPGGfvrpJ7333nuaO3dukbc7YsQIpaWl6ZFHHtH27dt14MABvffee9q/f78kaezYsZo2bZo+/PBD7d+/X88//7wSExM1atQoSQUbp8Jwd3fXc889p3Hjxunf//63Dh48qC1btmjBggW51g8fPlxnzpxRv379tG3bNh08eFDr1q3TwIEDnQoX9erV0/r165WcnKyzZ88Wuv9ASUcYAW4gT09PtW/fXjNnzlTnzp3VvHlzjR8/XkOGDNGbb77pUBsTE6OlS5eqZcuW+ve//60PPvjA/v/4K1asqI0bN6pu3br6y1/+oiZNmmjQoEG6ePGivL29JUkLFizQ2bNn1aZNGz322GMaOXKkfH19b8hxBQcH69VXX9W0adPUvHlzvf/++4qNjS3ydm+77TZ9+eWXSk9PV2hoqNq2bau3337b/nHGyJEjNWbMGD3zzDNq0aKF1q5dq08++USNGjWSVLBxKqzx48frmWee0YQJE9SkSRM9/PDDed7fce0KTlZWlrp3764WLVpo9OjRqly5ssN9ONczY8YMxcXFqU6dOmrdunWR+g+UZHwDK1AC8E2bAG5lXBkBAACWIowAAABL8WgvUALwaSmAWxlXRgAAgKUIIwAAwFKEEQAAYCnCCAAAsBRhBAAAWIowAgAALEUYAQAAliKMAAAASxFGAACApf4/hHFlcJuZ8c4AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(kdr_spearmans, bins=50)\n",
    "plt.title('KDR-Lo: Test clusters')\n",
    "plt.xlabel('Spearman coefficient')\n",
    "#plt.savefig('kcnh2_rho_distribution.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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.1</th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>smiles</th>\n",
       "      <th>value</th>\n",
       "      <th>cluster</th>\n",
       "      <th>preds</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>Brc1ccc(-c2nc3ccc(Nc4ncnc5ccccc45)cc3[nH]2)cc1</td>\n",
       "      <td>6.419075</td>\n",
       "      <td>51</td>\n",
       "      <td>6.136495</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\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",
       "      <td>6.908331</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\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",
       "      <td>7.283382</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\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",
       "      <td>6.921623</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\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",
       "      <td>7.112708</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\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>432</td>\n",
       "      <td>c1ccc2c(-c3cnn4cc(-c5ccc(N6CCNCC6)cc5)cnc34)cc...</td>\n",
       "      <td>6.666150</td>\n",
       "      <td>39</td>\n",
       "      <td>5.803215</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>433</th>\n",
       "      <td>433</td>\n",
       "      <td>433</td>\n",
       "      <td>c1ccc2c(-c3cnn4cc(-c5ccc(N6CCOCC6)cc5)cnc34)cc...</td>\n",
       "      <td>5.273191</td>\n",
       "      <td>39</td>\n",
       "      <td>5.888967</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>434</th>\n",
       "      <td>434</td>\n",
       "      <td>434</td>\n",
       "      <td>c1ccc2c(-c3cnn4cc(-c5ccc(OCCN6CCOCC6)cc5)cnc34...</td>\n",
       "      <td>5.616364</td>\n",
       "      <td>39</td>\n",
       "      <td>6.380241</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>435</th>\n",
       "      <td>435</td>\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",
       "      <td>6.614249</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>436</th>\n",
       "      <td>436</td>\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",
       "      <td>6.477106</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>437 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Unnamed: 0.1  Unnamed: 0  \\\n",
       "0               0           0   \n",
       "1               1           1   \n",
       "2               2           2   \n",
       "3               3           3   \n",
       "4               4           4   \n",
       "..            ...         ...   \n",
       "432           432         432   \n",
       "433           433         433   \n",
       "434           434         434   \n",
       "435           435         435   \n",
       "436           436         436   \n",
       "\n",
       "                                                smiles     value  cluster  \\\n",
       "0       Brc1ccc(-c2nc3ccc(Nc4ncnc5ccccc45)cc3[nH]2)cc1  6.419075       51   \n",
       "1     C=CC(=O)Nc1ccc(-c2ccc(NC(=O)Nc3ccc(F)cc3)cc2)cn1  8.047208       32   \n",
       "2    C=CC(=O)Nc1ccc(-c2ccc(NC(=O)Nc3cccc(C(C)C)c3)c...  8.508638       32   \n",
       "3    C=CC(=O)Nc1ccc(-c2ccc(NC(=O)Nc3cccc(Cl)c3)cc2)cn1  8.474955       32   \n",
       "4    C=CC(=O)Nc1cccc(-c2ccc(NC(=O)Nc3c(C)cccc3C)cc2)n1  6.380687       32   \n",
       "..                                                 ...       ...      ...   \n",
       "432  c1ccc2c(-c3cnn4cc(-c5ccc(N6CCNCC6)cc5)cnc34)cc...  6.666150       39   \n",
       "433  c1ccc2c(-c3cnn4cc(-c5ccc(N6CCOCC6)cc5)cnc34)cc...  5.273191       39   \n",
       "434  c1ccc2c(-c3cnn4cc(-c5ccc(OCCN6CCOCC6)cc5)cnc34...  5.616364       39   \n",
       "435      c1ccc2c(-c3nc4cc(-n5ccnc5)ccc4[nH]3)[nH]nc2c1  7.075721       45   \n",
       "436      c1ccc2c(-c3nc4cc(N5CCOCC5)ccc4[nH]3)[nH]nc2c1  6.793174       45   \n",
       "\n",
       "        preds  \n",
       "0    6.136495  \n",
       "1    6.908331  \n",
       "2    7.283382  \n",
       "3    6.921623  \n",
       "4    7.112708  \n",
       "..        ...  \n",
       "432  5.803215  \n",
       "433  5.888967  \n",
       "434  6.380241  \n",
       "435  6.614249  \n",
       "436  6.477106  \n",
       "\n",
       "[437 rows x 6 columns]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kdr = pd.read_csv('../../predictions/lo/kdr/svr_ecfp4/test_1.csv')\n",
    "kdr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "kdr_spearmans = []\n",
    "ps = []\n",
    "for i in range(1, kdr['cluster'].max()):\n",
    "    cluster = kdr[kdr['cluster'] == i]\n",
    "    spearman, p = spearmanr(cluster['value'], cluster['preds'])\n",
    "    if np.isnan(spearman):\n",
    "        spearman = 0.0\n",
    "    kdr_spearmans.append(spearman)\n",
    "    ps.append(p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAi4AAAHHCAYAAACY6dMIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABD2ElEQVR4nO3deVxXVeL/8ffHhQ874ga4IaLhilupaEmTKBgaVmNpTi6ZlaOpY1nRlKRWaG41o6mVS1lm2aT2LdPQokXR0jTXHNe0FFwyEExUOL8//PGZPrHIB3C58no+Hvcx3XPPPfecewHfc1ebMcYIAADAAipc7Q4AAAAUF8EFAABYBsEFAABYBsEFAABYBsEFAABYBsEFAABYBsEFAABYBsEFAABYBsEFAABYBsEFuE689NJLaty4sXJzc692VwrVoUMHPfHEE1e7G1eVzWbTc889d7W7AVgWwQWWtmDBAtlsNm3cuNGpPD09Xe3atZO7u7tWrlwpSXruuedks9kck6enp+rVq6eePXtq/vz5ys7Oztf+wIEDndax2+264YYbNHbsWJ09e7ZYfbz11lvVvHnz0g+2CBkZGZo0aZKefPJJVajwv1/rzMxMJSQkqHnz5vLy8lK1atXUqlUrjRw5UkeOHJEkhYeHq169eirq6x+dOnVSQECALly4oIMHDzr2x/PPP19g/X79+slms8nb29up/Mknn9TMmTOVmppaonHWr1/f6XgUNi1YsKBE7f/Ziy++qGXLlpVJW1fCkSNH9Nxzz2nLli1XuyvAZVPpancAKGsZGRnq1q2btm7dqqVLlyomJsZp+axZs+Tt7a3s7Gz98ssvWrVqlR544AG9/PLL+vjjj1W3bl2n+na7XW+88Yaki4Fo+fLlmjBhgvbt26d33nnnio2rKPPmzdOFCxfUt29fR9n58+fVuXNn/fjjjxowYIAeffRRZWZmaseOHVq0aJHuvPNO1apVS/369dNTTz2lr7/+Wp07d87X9sGDB5WSkqLhw4erUqX//clwd3fXu+++q2eeecapflZWlpYvXy53d/d8bcXFxcnX11evvvqqxo8f7/I4X375ZWVmZjrmV6xYoXfffVfTp09X9erVHeUdO3Z0ue2CvPjii/rrX/+qXr16lUl7l9uRI0c0btw41a9fX61atbra3QEuDwNY2Pz5840k89133xljjMnIyDAdOnQwbm5u5uOPP3aqm5CQYCSZ48eP52vn7bffNhUqVDDt27d3Kh8wYIDx8vJyKsvNzTUdOnQwNpvNpKamXrKPkZGRplmzZq4OzSXh4eHmb3/7m1PZ+++/bySZd955J1/933//3aSnpxtjjDl06JCx2Wzm4YcfLrDtF1980Ugy69evN8YYc+DAASPJ3HXXXUaS2bJli1P9d955x1SuXNn07Nkz374zxpjhw4eb4OBgk5ubW6Kx/tHkyZONJHPgwIFSt1UQLy8vM2DAgDJtU5JJSEgo0zbzfPfdd0aSmT9/fpm2m5mZWabtAaXBpSJcNzIzMxUTE6Pvv/9e//nPfxQbG1vsdfv166cHH3xQGzZsUFJSUpF1bTabbr75ZhljtH///tJ22+HVV19Vs2bNZLfbVatWLQ0bNky//fbbJdc7cOCAtm7dqqioKKfyffv2Sbp4mefP3N3d5evrK0mqW7euOnfurA8++EDnz5/PV3fRokUKDQ1V+/btncojIiIUEhKiRYsWOZW/8847iomJUdWqVQvsb9euXfXTTz/lu5yxb98+R59L6+2331bbtm3l4eGhqlWrqk+fPjp8+LBTnT179ujuu+9WYGCg3N3dVadOHfXp00fp6emSLh7nrKwsvfnmm45LUAMHDixyu2fPntVzzz2nG264Qe7u7goKCtJdd91V5LgGDhyo+vXr5yvPu7T5R0lJSbr55ptVpUoVeXt7KywsTE8//bQkKTk5WTfddJMkadCgQQVeNtuwYYNiYmLk5+cnT09PRUZGau3atQVud+fOnbrvvvvk7++vm2++WZKUmpqqQYMGqU6dOrLb7QoKClJcXJwOHjxY5H4ByhLBBdeFrKwsde/eXd99952WLFmiHj16uNzG/fffL0n67LPPLlk37w+1v7+/y9spyHPPPadhw4apVq1amjp1qu6++27NmTNH3bp1KzBM/NG6deskSW3atHEqDw4OliS99dZbRd6/Il0MbidPntSqVaucyrdt26bt27erX79+Ba7Xt29fLV682NH+iRMn9Nlnn+m+++4rdFtt27aVpHz/YHbp0kVdunQpsp/F8cILL6h///5q1KiRpk2bplGjRmnNmjXq3LmzIwieO3dO0dHRWr9+vR599FHNnDlTDz30kPbv3++os3DhQtntdt1yyy1auHChFi5cqIcffrjQ7ebk5KhHjx4aN26c2rZtq6lTp2rkyJFKT0/X9u3bSz2uHTt2qEePHsrOztb48eM1depU3XHHHY792KRJE8flt4ceesjR57zLf59//rk6d+6sjIwMJSQk6MUXX9Rvv/2m2267Td9++22+7fXu3VtnzpzRiy++qCFDhkiS7r77bi1dulSDBg3Sq6++qhEjRuj06dM6dOhQqccHFNtVPuMDlErepaLg4GBTuXJls2zZskLrFnWpyBhjTp06ZSSZO++801GWd6no+PHj5vjx42bv3r1mypQpxmazmebNmxfrcselLhUdO3bMuLm5mW7dupmcnBxH+YwZM4wkM2/evCLbf+aZZ4wkc/r0aafyM2fOmLCwMMf+GThwoJk7d65JS0vL18avv/5q7Ha76du3r1P5U089ZSSZ3bt3O8ryLhVNnjzZbN++3UgyX3/9tTHGmJkzZxpvb2+TlZVV4GW2PG5ubmbo0KFOZcHBwSY4OLjIsf7Zny8VHTx40FSsWNG88MILTvW2bdtmKlWq5CjfvHmzkWSWLFlSZPuuXCqaN2+ekWSmTZuWb9kff070p0tFAwYMKHDceT+veaZPn17kz68xhV8qys3NNY0aNTLR0dFOfTlz5owJCQkxXbt2zbfdP/8s5P1+TJ48udDtA1cCZ1xwXUhLS5O7u3u+G2tdkfcEzOnTp53Ks7KyVKNGDdWoUUMNGzbU448/rk6dOmn58uX5TuWXxOrVq3Xu3DmNGjXK6YmgIUOGyNfXV5988kmR6588eVKVKlXK9wSPh4eHNmzYoDFjxki6+ATW4MGDFRQUpEcffdTpKSp/f3/dfvvt+uijj5SVlSVJMsZo8eLFuvHGG3XDDTcUuO1mzZopPDxc7777rqSLl5Xi4uLk6elZZJ/9/f114sQJp7KDBw+W+pLDhx9+qNzcXN1zzz06ceKEYwoMDFSjRo30xRdfSJL8/PwkSatWrdKZM2dKtc08//nPf1S9enU9+uij+ZaVxc9JlSpVJEnLly93+ZH3LVu2aM+ePbrvvvt08uRJx37JyspSly5d9NVXX+Vr85FHHnGa9/DwkJubm5KTk3Xq1KlSjQUoDYILrgtz5syRm5ubYmJitHv37hK1kfe0io+Pj1O5u7u7kpKSlJSUpPnz56tJkyY6duyYPDw8nNZNTU11TMePHy/2dn/66SdJUlhYmFO5m5ubGjRo4FheEn5+fnrppZccoWDu3LkKCwvTjBkzNGHCBKe6/fr1czwRJF28BHXw4MFCLxPlue+++7RkyRLt3btX69atK/IyUR5jTJn8Y/5ne/bskTFGjRo1coTNvGnXrl06duyYJCkkJESjR4/WG2+8oerVqys6OlozZ8503N9SEvv27VNYWJjTk1dl6d5771WnTp304IMPKiAgQH369NH7779frBCzZ88eSdKAAQPy7Zc33nhD2dnZ+cYeEhLiNG+32zVp0iR9+umnCggIUOfOnfXSSy+V+NF2oKQILrguNG3aVCtWrNDvv/+url275rsRszjy7kNo2LChU3nFihUVFRWlqKgoDRw4UGvWrFFqaqrT/Q5TpkxRUFCQY8q7SfJKqFatmi5cuJDvTNGfBQcH64EHHtDatWtVpUqVfI9y9+jRQ35+fo6bbRctWqSKFSuqT58+Rbbbt29fnThxQkOGDFG1atXUrVu3S/b5t99+c3p8uazk5ubKZrNp5cqVjrD5x2nOnDmOulOnTtXWrVv19NNP6/fff9eIESPUrFkz/fzzz2Xer6IUFuBycnKc5j08PPTVV19p9erVuv/++7V161bde++96tq1a766f5YXbiZPnlzgfklKSirwjN2fjRo1Sv/973+VmJgod3d3Pfvss2rSpIk2b97sypCBUuE9LrhutGvXTsuWLVNsbKy6du2qr7/+WjVq1Cj2+gsXLpQkRUdHF1kvKChI//jHPzRu3DitX79eHTp0UP/+/R1PXkgF/9EvTN5NtLt371aDBg0c5efOndOBAwfyPS30Z40bN5Z08emi8PDwS27P399foaGh+W4Ytdvt+utf/6q33npLaWlpWrJkiW677TYFBgYW2V69evXUqVMnJScna+jQoZc84/DLL7/o3LlzatKkySX76qrQ0FAZYxQSElLo5a0/atGihVq0aKFnnnlG69atU6dOnTR79mzHi/VcOSsUGhqqDRs26Pz586pcuXKx1/P39y/w6bGCzrRVqFDBcRPztGnT9OKLL+qf//ynvvjiC0VFRRXa39DQUEmSr6/vJX+eLiU0NFSPPfaYHnvsMe3Zs0etWrXS1KlT9fbbb5eqXaC4OOOC60qXLl307rvvau/evYqJiVFGRkax1lu0aJHeeOMNRUREFOvJlkcffVSenp6aOHGiJKlBgwaOszJRUVEFPoJcmKioKLm5uelf//qX09M/c+fO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37+/jh49Kj8/P4WHh2vVqlXq2rWrJOnQoUOqUOF/J3FOnTqlIUOGKDU1Vf7+/mrbtq3WrVtX6M28AAAARXEpuMydO7fI5cnJyU7z06dP1/Tp013uFAAAQEH4VhEAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMggsAALAMl4LLrFmzFB4eLl9fX/n6+ioiIkKffvppkessWbJEjRs3lru7u1q0aKEVK1aUqsMAAKD8cim41KlTRxMnTtSmTZu0ceNG3XbbbYqLi9OOHTsKrL9u3Tr17dtXgwcP1ubNm9WrVy/16tVL27dvL5POAwCA8sWl4NKzZ0/dfvvtatSokW644Qa98MIL8vb21vr16wus/8orrygmJkZjxoxRkyZNNGHCBLVp00YzZswok84DAIDypcT3uOTk5Gjx4sXKyspSREREgXVSUlIUFRXlVBYdHa2UlJSSbhYAAJRjlVxdYdu2bYqIiNDZs2fl7e2tpUuXqmnTpgXWTU1NVUBAgFNZQECAUlNTi9xGdna2srOzHfMZGRmudhMAAFyHXA4uYWFh2rJli9LT0/XBBx9owIAB+vLLLwsNLyWRmJiocePGlVl7AC6P+k99csk6ByfGXoGeAKV3vf48X2/jcvlSkZubmxo2bKi2bdsqMTFRLVu21CuvvFJg3cDAQKWlpTmVpaWlKTAwsMhtxMfHKz093TEdPnzY1W4CAIDrUKnf45Kbm+t0WeePIiIitGbNGqeypKSkQu+JyWO32x2PXOdNAAAALl0qio+PV/fu3VWvXj2dPn1aixYtUnJyslatWiVJ6t+/v2rXrq3ExERJ0siRIxUZGampU6cqNjZWixcv1saNG/Xaa6+V/UgAAMB1z6XgcuzYMfXv319Hjx6Vn5+fwsPDtWrVKnXt2lWSdOjQIVWo8L+TOB07dtSiRYv0zDPP6Omnn1ajRo20bNkyNW/evGxHAQAAygWXgsvcuXOLXJ6cnJyvrHfv3urdu7dLnQIAACgI3yoCAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACWQXABAACW4VJwSUxM1E033SQfHx/VrFlTvXr10u7du4tcZ8GCBbLZbE6Tu7t7qToNAADKJ5eCy5dffqlhw4Zp/fr1SkpK0vnz59WtWzdlZWUVuZ6vr6+OHj3qmH766adSdRoAAJRPlVypvHLlSqf5BQsWqGbNmtq0aZM6d+5c6Ho2m02BgYEl6yEAAMD/V6p7XNLT0yVJVatWLbJeZmamgoODVbduXcXFxWnHjh2l2SwAACinShxccnNzNWrUKHXq1EnNmzcvtF5YWJjmzZun5cuX6+2331Zubq46duyon3/+udB1srOzlZGR4TQBAAC4dKnoj4YNG6bt27frm2++KbJeRESEIiIiHPMdO3ZUkyZNNGfOHE2YMKHAdRITEzVu3LiSdg0AAFynSnTGZfjw4fr444/1xRdfqE6dOi6tW7lyZbVu3Vp79+4ttE58fLzS09Md0+HDh0vSTQAAcJ1x6YyLMUaPPvqoli5dquTkZIWEhLi8wZycHG3btk233357oXXsdrvsdrvLbQMAgOubS8Fl2LBhWrRokZYvXy4fHx+lpqZKkvz8/OTh4SFJ6t+/v2rXrq3ExERJ0vjx49WhQwc1bNhQv/32myZPnqyffvpJDz74YBkPBQAAXO9cCi6zZs2SJN16661O5fPnz9fAgQMlSYcOHVKFCv+7AnXq1CkNGTJEqamp8vf3V9u2bbVu3To1bdq0dD0HAADljsuXii4lOTnZaX769OmaPn26S50CAAAoCN8qAgAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFwAQAAlkFw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pUuXmj//6Suo7I9nXDIyMozdbjevv/56gf368xmXCRMmmG7dujnVOXz4sJHk+PJxZGSkufnmm/ON5cknn3TMSzJLly4tcJtAecUZF+Ayu/vuu3XkyBF99NFHiomJUXJystq0aaMFCxY41YuIiMg3n3fG5YcfftDevXvl4+PjOItTtWpVnT171nF/RlpamoYMGaJGjRrJz89Pvr6+yszM1KFDh5zavfHGG/P1sX79+vLx8XHMBwQEqGnTpqpQoYJT2bFjxxzzq1evVpcuXVS7dm35+Pjo/vvv18mTJ3XmzBlHHU9PT4WGhjrmg4KCnNr4sy1btuiWW24p8L6bjIwMHTlyJN8NzZ06dXJpP5XErl27lJ2drS5duhSr/g8//KAvvvjC0Qdvb281btxYkpz6ER4e7rTepfYPAG7OBa4Id3d3de3aVV27dtWzzz6rBx98UAkJCRo4cGCx1s/MzFTbtm31zjvv5FtWo0YNSdKAAQN08uRJvfLKKwoODpbdbldERITjUlIeLy+vfG38OSjYbLYCy3JzcyVdfPy3R48eGjp0qF544QVVrVpV33zzjQYPHqxz587J09Oz0HZNEQ8yenh4FLqsOIqzn0rC1X5lZmaqZ8+emjRpUr5lQUFBjv8uah8DKBhnXICroGnTpsrKynIqW79+fb75Jk2aSJLatGmjPXv2qGbNmmrYsKHT5OfnJ0lau3atRowYodtvv13NmjWT3W7XiRMnLkv/N23apNzcXE2dOlUdOnTQDTfcoCNHjpS63fDwcH399dc6f/58vmW+vr6qVauW1q5d61S+du1aNW3aVFLx9lNJNGrUSB4eHlqzZk2x6rdp00Y7duxQ/fr18/WjoOBYmMqVKysnJ6ek3QauSwQX4DI6efKkbrvtNr399tvaunWrDhw4oCVLluill15SXFycU90lS5Zo3rx5+u9//6uEhAR9++23Gj58uCSpX79+ql69uuLi4vT111/rwIEDSk5O1ogRI/Tzzz9LuviP68KFC7Vr1y5t2LBB/fr1K/UZjMI0bNhQ58+f17///W/t379fCxcu1OzZs0vd7vDhw5WRkaE+ffpo48aN2rNnjxYuXKjdu3dLksaMGaNJkybpvffe0+7du/XUU09py5YtGjlypKTi7aeScHd315NPPqknnnhCb731lvbt26f169dr7ty5BdYfNmyYfv31V/Xt21ffffed9u3bp1WrVmnQoEEuBZH69etrzZo1Sk1N1alTp0rcf+B6QnABLiNvb2+1b99e06dPV+fOndW8eXM9++yzGjJkiGbMmOFUd9y4cVq8eLHCw8P11ltv6d1333WcSfD09NRXX32levXq6a677lKTJk00ePBgnT17Vr6+vpKkuXPn6tSpU2rTpo3uv/9+jRgxQjVr1rws42rZsqWmTZumSZMmqXnz5nrnnXeUmJhY6narVaumzz//XJmZmYqMjFTbtm31+uuvOy6pjBgxQqNHj9Zjjz2mFi1aaOXKlfroo4/UqFEjScXbTyX17LPP6rHHHtPYsWPVpEkT3XvvvYXej5J3ZignJ0fdunVTixYtNGrUKFWpUsXpvqFLmTp1qpKSklS3bl21bt26VP0Hrhe8ORe4BvCGVAAoHs64AAAAyyC4AAAAy+BxaOAawBVbACgezrgAAADLILgAAADLILgAAADLILgAAADLILgAAADLILgAAADLILgAAADLILgAAADLILgAAADL+H+/ESWQkm60rgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(kdr_spearmans, bins=50)\n",
    "plt.title('KDR-Lo (SVM): Test clusters')\n",
    "plt.xlabel('Spearman coefficient')\n",
    "plt.savefig('kdr_svm_rho_distribution.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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",
       "      <th>preds</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",
       "      <td>6.044301</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",
       "      <td>6.586384</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",
       "      <td>6.730017</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",
       "      <td>6.272653</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",
       "      <td>6.489970</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\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",
       "      <td>6.387982</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",
       "      <td>6.440312</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",
       "      <td>6.742176</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",
       "      <td>6.260894</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",
       "      <td>6.130262</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>437 rows × 5 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     preds  \n",
       "0         51  6.044301  \n",
       "1         32  6.586384  \n",
       "2         32  6.730017  \n",
       "3         32  6.272653  \n",
       "4         32  6.489970  \n",
       "..       ...       ...  \n",
       "432       39  6.387982  \n",
       "433       39  6.440312  \n",
       "434       39  6.742176  \n",
       "435       45  6.260894  \n",
       "436       45  6.130262  \n",
       "\n",
       "[437 rows x 5 columns]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kdr = pd.read_csv('../../predictions/lo/kdr/chemprop/test_1.csv')\n",
    "kdr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "kdr_spearmans = []\n",
    "ps = []\n",
    "for i in range(1, kdr['cluster'].max()):\n",
    "    cluster = kdr[kdr['cluster'] == i]\n",
    "    spearman, p = spearmanr(cluster['value'], cluster['preds'])\n",
    "    if np.isnan(spearman):\n",
    "        spearman = 0.0\n",
    "    kdr_spearmans.append(spearman)\n",
    "    ps.append(p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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3LixOnXqpI8//thtXUOGDHEZHzZsmCS51c06WnXl6QFjTIHvwMhrH5cqVUqS9N///veqR7by6t///reaNGmiHj16uE2zsb+XKlVK58+fv+opx+ysWbNGv/zyi3r37u3SL97e3mrZsqXbvidJTz75pMt4cHCwJGn16tW6cOFC/jYCRRLBAh55++235ePjo+joaO3duzdfy0hNTZXk/kPs6+urNWvWaM2aNYqPj1f9+vV18uRJ+fn5ucx7/Phx53Dq1Kk8r/fHH3+UJNWtW9el3MfHRzVr1nRO91RQUJAk96CUG19fX5cfZum3H9A/ntfft2+fkpKSFBIS4gxcWUNqaqpOnjzpMv8fw4P0+xf7lSEwq/zKawiKFSummjVrupTVqVNHktwOfdeoUcNlPKe+lX47ZXH69GmdP3/epbx27dou42FhYSpWrJjbusz/f42HjR/bK+W1jyMiItSzZ0/FxcWpXLly6t69e463TufV/v37C/X26Keeekp16tRR586dVblyZQ0cONB5S/jV7Nu3T9JvofTKfvnkk0/c9r3ixYurcuXKLmU1atTQiBEj9M4776hcuXKKiorSzJkzub7iFsBdIfBIgwYN9PHHH6tDhw7q1KmT1q9f7/HRix9++EGSVKtWLZdyb29vlwsjo6KiVK9ePT3++OPO6ximTp3qvKVPkqpVq3bN7sEvW7as0tPTlZKS4hKK6tWrJ0nasWOH2rZtm6dleXt7X7VOZmamQkJCcrzV9spgktMycyo3f7go01N/DHu25BQcsgLQH+8wsiWvfezl5aUlS5YoISFB//nPf5y3Tk+bNk0JCQnX9IFnXl5e2X52V174GxISom3btmn16tVauXKlVq5cqfj4ePXt21fz5s3LdR1Z19/Mnz9fFSpUcJtevLjrT4fD4XB7roskTZs2Tf3799fy5cv1ySefaPjw4Zo4caISEhLcgghuHgQLeKxFixZatmyZYmJi1KlTJ3311VduP3K5yXqGQFRUVK71KlasqGeffVZxcXFKSEjQXXfdpb59+6pNmzbOOp78wFWrVk2StHfvXpf/mV+6dEkHDx50u9vjSlkB4uDBg2rcuLGzPOtiyffeey/PwSIvwsLCtHbtWrVu3bpQfsivlJmZqQMHDjiPUkhyPtjras84+GPfXmnPnj0qV66c2+2H+/btcznykZiYqMzMTLd1HTx4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AACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKzxOFh8+eWX6tq1qypVqiQvLy8tW7asEJoFAACKIo+Dxfnz59WkSRPNnDmzMNoDAACKsOKeztC5c2d17ty5MNoCAACKOI+DhafS0tKUlpbmHE9OTi7sVQIAgOuk0IPFxIkTFRcXV9irkSRVH73imqznWq8LucvLZ3FoUsw1aEneFdX950Zr97X87G+0bbflZt2uvLjRfjPysq8Whe+7Qr8rZMyYMUpKSnIOR44cKexVAgCA66TQj1g4HA45HI7CXg0AALgB8BwLAABgjcdHLFJTU5WYmOgcP3jwoLZt26YyZcqoatWqVhsHAACKFo+DxebNm/WnP/3JOT5ixAhJUr9+/TR37lxrDQMAAEWPx8GiXbt2MsYURlsAAEARxzUWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArMlXsJg5c6aqV68uX19ftWzZUt9++63tdgEAgCLI42DxwQcfaMSIEYqNjdV3332nJk2aKCoqSidPniyM9gEAgCLE42Axffp0DR48WAMGDFCDBg301ltvyd/fX3PmzCmM9gEAgCLEo2Bx6dIl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aqqGDx9urf025bcvHn74YVWrVk2VKlXS999/r1GjRmnv3r368MMPncu98hHrWeN57ePrwca+cfr0aU2YMEGPPfaYS/mNvG+cPn1aGRkZ2X5me/bsyXaenD7jrH7K+jO3Ojei/PTFlUaNGqVKlSq5fEFGR0fr/vvvV40aNbR//3799a9/VefOnbVhwwZ5e3tb3Qab8tMfdevW1Zw5c9S4cWMlJSVp6tSpuvvuu7Vz505Vrlz5lt03vv32W/3www+aPXu2S3lR3Tc8ldN3RnJysn799VedO3euwP/2slgLFqNHj9bkyZNzrbN79+4Cr+fXX3/VwoULNXbsWLdpfyy7/fbbdf78eb3yyivX/MejsPvijz+a4eHhqlixojp06KD9+/crLCws38stLNdq30hOTlZMTIwaNGig8ePHu0y7UfYNFK5JkyZp0aJFWrduncsFi7169XL+PTw8XI0bN1ZYWJjWrVunDh06XI+mFppWrVqpVatWzvG7775b9evX19tvv60JEyZcx5ZdX7Nnz1Z4eLhatGjhUn4r7RvXirVg8dxzz6l///651qlZs6YqVKigkydPupSnp6fr7NmzqlChwlXXs2TJEl24cEF9+/a9at2WLVtqwoQJSktLu6bPib9WfZGlZcuWkqTExESFhYWpQoUKblfynjhxQpI8Wq4t16I/UlJSFB0drcDAQC1dulQlSpTItf712jeyU65cOXl7ezs/oywnTpzIcbsrVKiQa/2sP0+cOKGKFSu61GnatKnF1tuVn77IMnXqVE2aNElr165V48aNc61bs2ZNlStXTomJiTf0j0dB+iNLiRIldPvttysxMVHSrblvnD9/XosWLdJLL7101fUUlX3DUzl9ZwQFBcnPz0/e3t4F3tecPLoiw4KsC/Q2b97sLFu9enWeL9CLiIhwu+I/J3/7299M6dKl893WwlbQvsjy9ddfG0lm+/btxpjfL97845W8b7/9tgkKCjIXL160twGW5bc/kpKSzF133WUiIiLM+fPn87SuG23faNGihRk6dKhzPCMjw9x22225XrzZpUsXl7JWrVq5Xbw5depU5/SkpKQic4GeJ31hjDGTJ082QUFBZsOGDXlax5EjR4yXl5dZvnx5gdtb2PLTH3+Unp5u6tata5599lljzK23bxjz2wWtDofDnD59+qrrKEr7Rhbl8eLNRo0auZT17t3b7eLNguxrzvZ4VNuS6Ohoc/vtt5uNGzear7/+2tSuXdvllsKffvrJ1K1b12zcuNFlvn379hkvLy+zcuVKt2V+9NFHZtasWWbHjh1m37595o033jD+/v5m3Lhxhb49BeFpXyQmJpqXXnrJbN682Rw8eNAsX77c1KxZ09xzzz3OebJuN42MjDTbtm0zq1atMuXLly8yt5t60h9JSUmmZcuWJjw83CQmJrrcMpaenm6MKRr7xqJFi4zD4TBz5841u3btMo899pgpVaqU886eRx55xIwePdpZf/369aZ48eJm6tSpZvfu3SY2Njbb201LlSplli9fbr7//nvTvXv3InNLoSd9MWnSJOPj42OWLFni8vln3YqekpJinn/+ebNhwwZz8OBBs3btWtOsWTNTu3btGzpoZ/G0P+Li4szq1avN/v37zZYtW0yvXr2Mr6+v2blzp7POrbJvZGnTpo156KGH3MqL8r6RkpJitm7darZu3WokmenTp5utW7eaH3/80RhjzOjRo80jjzzirJ91u+nIkSPN7t27zcyZM7O93TS3/s2r6xIszpw5Y3r37m0CAgJMUFCQGTBggMvzKA4ePGgkmc8//9xlvjFjxpgqVaqYjIwMt2WuXLnSNG3a1AQEBJiSJUuaJk2amLfeeivbujcST/vi8OHD5p577jFlypQxDofD1KpVy4wcOdLlORbGGHPo0CHTuXNn4+fnZ8qVK2eee+45l9svb1Se9sfnn39uJGU7HDx40BhTdPaNGTNmmKpVqxofHx/TokULk5CQ4JwWERFh+vXr51L/X//6l6lTp47x8fExDRs2NCtWrHCZnpmZacaOHWtCQ0ONw+EwHTp0MHv37r0Wm1JgnvRFtWrVsv38Y2NjjTHGXLhwwURGRpry5cubEiVKmGrVqpnBgwd7/GV5PXnSH88884yzbmhoqLn33nvNd99957K8W2XfMMaYPXv2GEnmk08+cVtWUd43cvruy9r+fv36mYiICLd5mjZtanx8fEzNmjVdnueRJbf+zStemw4AAKzhXSEAAMAaggUAALCGYAEAAKwhWAAAAGsIFgAAwBqCBQAAsIZgAQAArCFYACiyxo8fr9DQUHl5eWnZsmXZlvXv31/33XdfnpZ36NAheXl5adu2bYXWZuBmxwOygDw6deqUxo0bpxUrVujEiRMqXbq0mjRponHjxql169bXu3m3nN27d6tBgwZaunSp7rrrLpUuXVoHDhxwK7t48aKMMSpVqtRVl5mRkaFTp06pXLlyKl7c2jsa5eXlpaVLl+Y54ABFmb1/OcBNrmfPnrp06ZLmzZunmjVr6sSJE/r000915syZ6900Xb58+apvdL3Z7N+/X5LUvXt3eXl55Vjmydtrvb29r8sbgIGbiscPAQduQefOnTOSzLp163KtJ8m88cYbJjo62vj6+poaNWqYxYsXu9Q5fPiweeCBB0xwcLApXbq06datm/O9JsYY8+2335qOHTuasmXLmqCgIHPPPfeYLVu2ZLuerl27Gn9/fxMbG2tiY2NNkyZNzOzZs02VKlVMyZIlzZNPPmnS09PN5MmTTWhoqClfvrz529/+5rKsadOmmUaNGhl/f39TuXJl8+STT7q8nyU+Pt4EBwebVatWmXr16pmSJUuaqKgoc/To0Vz74ocffjAxMTEmMDDQBAQEmDZt2pjExERjzG9vTYyLizO33Xab8fHxMU2aNHF7uWBu/RQbG5vtu0GuLDPmt3cmdO/e3bncjIwMM3nyZBMWFmZ8fHxMlSpVnH2S9S6arVu3Ouvv2LHDREdHm5IlS5qQkBDzl7/8xZw6dco5PSIiwgwbNsyMHDnSlC5d2oSGhjrfU2KM+7tMqlWrlmu/AUUd11gAeRAQEKCAgAAtW7ZMaWlpudYdO3asevbsqe3bt6tPnz7q1auXdu/eLem3IwtRUVEKDAzUV199pfXr1ysgIEDR0dG6dOmSJCklJUX9+vXT119/rYSEBNWuXVv33nuvUlJSXNYzfvx49ejRQzt27NDAgQMl/fY/9pUrV2rVqlV6//33NXv2bMXExOinn37SF198ocmTJ+vFF1/Uxo0bncspVqyY/vGPf2jnzp2aN2+ePvvsM73wwgsu67pw4YKmTp2q+fPn68svv9Thw4f1/PPP59gHP//8s+655x45HA599tln2rJliwYOHKj09HRJ0muvvaZp06Zp6tSp+v777xUVFaVu3bpp3759eeqn559/XvHx8ZKkY8eO6dixY9mWZWfMmDGaNGmSxo4dq127dmnhwoUKDQ3Ntu4vv/yi9u3b6/bbb9fmzZu1atUqnThxQg8++KBLvXnz5qlkyZLauHGjpkyZopdeeklr1qyRJG3atEmSFB8fr2PHjjnHgZvW9U42QFGxZMkSU7p0aePr62vuvvtuM2bMGLN9+3aXOpLME0884VLWsmVL8+STTxpjjJk/f76pW7euyczMdE5PS0szfn5+ZvXq1dmuNyMjwwQGBpr//Oc/Lut55plnXOrFxsYaf39/k5yc7CyLiooy1atXd3mTa926dc3EiRNz3M7FixebsmXLOsfj4+ONJOfRBmOMmTlzpgkNDc1xGWPGjDE1atQwly5dynZ6pUqVzMsvv+xSduedd5qnnnrKGJO3flq6dKm58issu7I/HrFITk42DofDzJo1K9t2XXnEYsKECSYyMtKlzpEjR4wk59tAIyIiTJs2bdy2ZdSoUc5xSWbp0qXZrhO42XDEAsijnj176ujRo/roo48UHR2tdevWqVmzZpo7d65LvVatWrmNZx2x2L59uxITExUYGOg8ClKmTBldvHjReX3AiRMnNHjwYNWuXVvBwcEKCgpSamqqDh8+7LLcO+64w62N1atXV2BgoHM8NDRUDRo0ULFixVzKTp486Rxfu3atOnTooNtuu02BgYF65JFHdObMGV24cMFZx9/fX2FhYc7xihUruizjStu2bVPbtm2zve4jOTlZR48edbvgtXXr1h71U37s3r1baWlp6tChQ57qb9++XZ9//rmzDQEBAapXr54kubSjcePGLvNdrX+AmxkXbwIe8PX1VadOndSpUyeNHTtWjz76qGJjY9W/f/88zZ+amqrmzZtrwYIFbtPKly8vSerXr5/OnDmj1157TdWqVZPD4VCrVq2cp0qylCxZ0m0ZV/6Qe3l5ZVuWmZkp6bfbK7t06aInn3xSL7/8ssqUKaOvv/5agwYN0qVLl+Tv75/jck0uN5T5+fnlOC0v8tJP+eFpu1JTU9W1a1dNnjzZbVrFihWdf8+tj4FbDUcsgAJo0KCBzp8/71KWkJDgNl6/fn1JUrNmzbRv3z6FhISoVq1aLkNwcLAkaf369Ro+fLjuvfdeNWzYUA6HQ6dPny6U9m/ZskWZmZmaNm2a7rrrLtWpU0dHjx4t8HIbN26sr776SpcvX3abFhQUpEqVKmn9+vUu5evXr1eDBg0k5a2f8qN27dry8/PTp59+mqf6zZo1086dO1W9enW3dmQX7HJSokQJZWRk5LfZQJFCsADy4MyZM2rfvr3ee+89ff/99zp48KAWL16sKVOmqHv37i51Fy9erDlz5uh///ufYmNj9e2332ro0KGSpD59+qhcuXLq3r27vvrqKx08eFDr1q3T8OHD9dNPP0n67cdv/vz52r17tzZu3Kg+ffoU+AhATmrVqqXLly9rxowZOnDggObPn6+33nqrwMsdOnSokpOT1atXL23evFn79u3T/PnztXfvXknSyJEjNXnyZH3wwQfau3evRo8erW3btunpp5+WlLd+yg9fX1+NGjVKL7zwgt59913t379fCQkJmj17drb1hwwZorNnz6p3797atGmT9u/fr9WrV2vAgAEeBYXq1avr008/1fHjx3Xu3Ll8tx8oCggWQB4EBASoZcuW+vvf/6577rlHjRo10tixYzV48GC9/vrrLnXj4uK0aNEiNW7cWO+++67ef/995//E/f399eWXX6pq1aq6//77Vb9+fQ0aNEgXL15UUFCQJGn27Nk6d+6cmjVrpkceeUTDhw9XSEhIoWxXkyZNNH36dE2ePFmNGjXSggULNHHixAIvt2zZsvrss8+UmpqqiIgINW/eXLNmzXKeMhg+fLhGjBih5557TuHh4Vq1apU++ugj1a5dW1Le+im/xo4dq+eee07jxo1T/fr19dBDD+V4PUTWkZWMjAxFRkYqPDxczzzzjEqVKuVy3crVTJs2TWvWrFGVKlV0++23F6j9wI2OJ28CFvGERQC3Oo5YAAAAawgWAADAGm43BSzizCKAWx1HLAAAgDUECwAAYA3BAgAAWEOwAAAA1hAsAACANQQLAABgDcECAABYQ7AAAADWECwAAIA1/x/aZFaiHjKHVwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(kdr_spearmans, bins=50)\n",
    "plt.title('KDR-Lo (Chemprop): Test clusters')\n",
    "plt.xlabel('Spearman coefficient')\n",
    "plt.savefig('kdr_chemprop_rho_distribution.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
}
