{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib_venn import venn3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../../code')\n",
    "\n",
    "from splits import get_hi_split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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>smiles</th>\n",
       "      <th>value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Brc1ccc(-[n+]2cc[n+](Cc3ccccc3)cc2)c2cc[nH]c12</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Brc1ccc(CNCCN2CCN(Cc3cc4ccccc4[nH]3)CC2)cc1</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Brc1ccc(N2CCN(Cc3ccccc3)CC2)c2cc[nH]c12</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Brc1ccc(NCCN2CCN(CCc3c[nH]c4ccccc34)CC2)cc1</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Brc1ccc(NCCN2CCN(Cc3cc4ccccc4[nH]3)CC2)cc1</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6262</th>\n",
       "      <td>c1cnc(N2CCN(CCCOc3ccc(-c4nc5ccccc5o4)cc3)CC2)nc1</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6263</th>\n",
       "      <td>c1cnc(N2CCN(CCCSc3nc4ccccc4s3)CC2)nc1</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6264</th>\n",
       "      <td>c1cnc(N2CCN(Cc3c[nH]c4ncccc34)CC2)nc1</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6265</th>\n",
       "      <td>c1cncc(CN[C@H]2C3C4CC5C6C4CC3C6C52)c1</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6266</th>\n",
       "      <td>c1nc2c(s1)CCN(CCCCN1CCc3ncsc3CC1)CC2</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>6267 rows × 2 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                smiles  value\n",
       "0       Brc1ccc(-[n+]2cc[n+](Cc3ccccc3)cc2)c2cc[nH]c12   True\n",
       "1          Brc1ccc(CNCCN2CCN(Cc3cc4ccccc4[nH]3)CC2)cc1  False\n",
       "2              Brc1ccc(N2CCN(Cc3ccccc3)CC2)c2cc[nH]c12   True\n",
       "3          Brc1ccc(NCCN2CCN(CCc3c[nH]c4ccccc34)CC2)cc1   True\n",
       "4           Brc1ccc(NCCN2CCN(Cc3cc4ccccc4[nH]3)CC2)cc1   True\n",
       "...                                                ...    ...\n",
       "6262  c1cnc(N2CCN(CCCOc3ccc(-c4nc5ccccc5o4)cc3)CC2)nc1   True\n",
       "6263             c1cnc(N2CCN(CCCSc3nc4ccccc4s3)CC2)nc1   True\n",
       "6264             c1cnc(N2CCN(Cc3c[nH]c4ncccc34)CC2)nc1  False\n",
       "6265             c1cncc(CN[C@H]2C3C4CC5C6C4CC3C6C52)c1  False\n",
       "6266              c1nc2c(s1)CCN(CCCCN1CCc3ncsc3CC1)CC2  False\n",
       "\n",
       "[6267 rows x 2 columns]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "drd2_hi = pd.read_csv('../../data/raw/drd2_hi.csv', index_col=0)\n",
    "drd2_hi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train: 5013 test: 188\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Shortest distance between train and test')"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAh8AAAGzCAYAAACPa3XZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAyL0lEQVR4nO3dd3hU1d7+/zsJJIFUWiABDBFUqiBV0ASESBEpoqJiCaigD12+BwELGEQDqBhEiqCCcqRYKD56QLqAFBEIR1ApCogioScUDZBZvz/8ZR4mjYAzK0x4v65rLp09a/Zan9l7Nvesmb3jY4wxAgAAsMS3sAcAAACuLYQPAABgFeEDAABYRfgAAABWET4AAIBVhA8AAGAV4QMAAFhF+AAAAFYRPgAAgFWEj2uYj4+P+vbtW9jDuOqsWrVKPj4+WrVqlXNZ9+7dVaVKlUIb09Wge/fuCg4OLuxh4CJVqlRR9+7dC3sYV8THx0cvvfRSYQ8DhYTwUQR9//33uu+++xQdHa3AwEBVrFhRd955pyZMmFBoY1q3bp1eeuklnTx50qP9vPrqq1qwYIFH+yioH374QS+99JL27dtX2EO5ak2aNEkzZswo7GF4jK39vqg6ePCgXnrpJaWkpHi0n1mzZik5OdmjfcAV4aOIWbdunRo2bKht27apZ8+eevvtt/Xkk0/K19dX48ePL9RxJSYmem34mDZtmnbu3HlZz/nhhx+UmJhI+MjHtRA+PLnf79y5U9OmTfPIuq8GBw8eVGJiIuGjCCpW2AOAe73yyisKCwvTpk2bFB4e7vLY4cOHrY/nzJkzCgoKst6vuxUvXrywh4AizuFw6Ny5cwoMDCzwcwICAjw4IsCDDIqUm266ybRo0aJAbSWZPn36mPnz55tatWoZf39/U7NmTbNo0aIcbbds2WLatm1rQkJCTFBQkGnZsqVZv369S5vp06cbSWbVqlXmf/7nf0y5cuVMeHi4GTFihJGU47Z3717nc2fOnGnq169vAgMDTalSpcwDDzxgfv31V5f179q1y3Tp0sWUL1/eBAQEmIoVK5oHHnjAnDx50llP9ltCQkK+r8GBAwdMp06dTMmSJU25cuXMwIEDzeLFi40ks3LlSme7hIQEEx0d7fLc2bNnm/r165vg4GATEhJiateubZKTk11ei+y3rHUuWLDA3HXXXSYyMtL4+/ub66+/3owcOdJcuHDBpY/mzZubWrVqmR07dpgWLVqYEiVKmKioKDNmzJgctfz5559mxIgR5oYbbjABAQGmQoUK5p577jF79uxxtsnMzDRvvvmmqVmzpgkICDARERGmV69e5vjx4/m+TlmvQVBQkPn5559N69atTcmSJU1kZKRJTEw0DofDpW1B+omOjs7x+jRv3tycOHHC+Pr6mvHjxzvbHjlyxPj4+JjSpUu79PX000+b8uXLu/S9YcMG06ZNGxMaGmpKlChh4uLizNq1a3PU89tvv5kePXqYiIgI577/3nvvubRZuXKlkWTmzp1rRo0aZSpWrGgCAgJMy5Ytze7du/N9vS6132e9//7973+bmjVrmmLFipn58+cbY4x57bXXTNOmTU3p0qVNYGCgqV+/vvnkk09y9BEdHe2yj2ftd2vXrjXPPPOMKVu2rClZsqTp3LmzOXz4cL7jNcaYbdu2mYSEBBMTE2MCAgJM+fLlTY8ePczRo0dzrW337t0mISHBhIWFmdDQUNO9e3dz5swZl7Z//fWXGThwoClbtqwJDg42HTp0MAcOHDCSzIgRI/IcS9Zrn/02ffp0Z5uCbOv09HQzYMAAEx0dbfz9/U25cuVMfHy82bx5szHm7/dY9j6yv9fhfsx8FDHR0dFav369tm/frtq1a1+y/dq1azVv3jz17t1bISEheuutt3Tvvffq119/VZkyZSRJO3bsUGxsrEJDQ/Xss8+qePHieuedd9SiRQt9/fXXatKkics6e/furXLlymn48OE6c+aM2rVrp127dmn27Nl68803VbZsWUlSuXLlJP09W/Piiy+qa9euevLJJ3XkyBFNmDBBcXFx2rp1q8LDw3Xu3Dm1adNGGRkZ6tevnypUqKDff/9dX3zxhU6ePKmwsDDNnDlTTz75pBo3bqxevXpJkqpWrZpn7X/++adatWqlX3/9Vf3791dUVJRmzpypFStWXPJ1W7p0qR566CG1atVKY8aMkST9+OOP+uabbzRgwADFxcWpf//+euutt/Tcc8+pRo0akuT874wZMxQcHKxBgwYpODhYK1as0PDhw5Wenq7XXnvNpa8TJ06obdu26tKli7p27apPP/1UQ4YMUZ06ddSuXTtJUmZmpu6++24tX75cDz74oAYMGKBTp05p6dKl2r59u/N1eOqppzRjxgz16NFD/fv31969e/X2229r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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "train_1, test_1, sim_1 = get_hi_split(drd2_hi, threshold=0.4, seed=322, cutoff=0.55)\n",
    "print('Train: ' + str(len(train_1)) + ' test: ' + str(len(test_1)))\n",
    "plt.hist(sim_1, bins=50)\n",
    "plt.title('Shortest distance between train and test')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train: 5013 test: 188\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Shortest distance between train and test')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiEAAAGzCAYAAAD5UcdSAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA0CElEQVR4nO3df3zN9eP///s2dsZ++rGxoVko+RERojZi+ZH8SKWil1lFvQi1y6tQoUlN9JJ+qlQq/aAfVO96Ufn1Qn4kzKsoIbSSKbJhGXYe3z/67vlx9sM2ne1hp9v1cnle6jyfj/N8PB7n+XzY/TzOeT6PnzHGCAAAoIL5224AAAD4eyKEAAAAKwghAADACkIIAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghPyN+fn56a677rLdjHPOihUr5OfnpxUrVjjrhg4dqoYNG1pr07lg6NChCgkJsd0MnKZhw4YaOnSo7WacFT8/Pz300EO2mwHLCCE+6Ouvv9b111+v2NhYBQUFqV69errqqqv09NNPW2vTmjVr9NBDD+nw4cPlWs+jjz6qDz74oFzrKK1t27bpoYce0p49e2w35Zz13HPP6dVXX7XdjHJTUee9r9q3b58eeughpaenl2s9b731lmbOnFmudaBohBAfs2bNGl166aXasmWLhg0bpmeeeUa33367/P399eSTT1ptV2pqaqUNIbNnz9b27dvL9Jxt27YpNTWVEHIGf4cQUp7n/fbt2zV79uxy2fe5YN++fUpNTSWE+LAqthsA73rkkUcUHh6uDRs2KCIiwmPbgQMHKrw9x44dU3BwcIXX621Vq1a13QT4OLfbrRMnTigoKKjUz3G5XOXYIqACGPiUCy+80HTp0qVUZSWZkSNHmoULF5rmzZubwMBA06xZM7No0aJCZTdt2mR69uxpQkNDTXBwsOnatatZu3atR5k5c+YYSWbFihXmn//8p4mMjDQRERFm0qRJRlKhZffu3c5z586da9q0aWOCgoJMjRo1zI033mh+/PFHj/1///33ZsCAAaZOnTrG5XKZevXqmRtvvNEcPnzY6U/BJSkp6YyvQUZGhunXr5+pXr26iYyMNHfffbdZvHixkWSWL1/ulEtKSjKxsbEez3377bdNmzZtTEhIiAkNDTUtWrQwM2fO9HgtCi75+/zggw/M1VdfbaKjo01gYKA5//zzzeTJk82pU6c86ujcubNp3ry52bp1q+nSpYupVq2aiYmJMY899lihvvzxxx9m0qRJpkmTJsblcpm6deuaa6+91uzcudMpk5eXZ5544gnTrFkz43K5TFRUlBk+fLg5dOjQGV+n/NcgODjY7Nq1y3Tv3t1Ur17dREdHm9TUVON2uz3Klqae2NjYQq9P586dze+//278/f3Nk08+6ZT99ddfjZ+fn6lZs6ZHXXfeeaepU6eOR93r1q0zPXr0MGFhYaZatWomISHBrF69ulB/fvrpJ5OcnGyioqKcc//ll1/2KLN8+XIjycyfP99MmTLF1KtXz7hcLtO1a1ezY8eOM75eJZ33+ePvjTfeMM2aNTNVqlQxCxcuNMYYM336dNOxY0dTs2ZNExQUZNq0aWPefffdQnXExsZ6nOP5593q1avNPffcY2rXrm2qV69u+vfvbw4cOHDG9hpjzJYtW0xSUpKJi4szLpfL1KlTxyQnJ5vffvutyL7t2LHDJCUlmfDwcBMWFmaGDh1qjh075lH2+PHj5u677za1a9c2ISEhpk+fPiYjI8NIMpMmTSq2LfmvfcFlzpw5TpnSHOvs7GwzZswYExsbawIDA01kZKRJTEw0GzduNMb8OcYK1lFwrKP8MBPiY2JjY7V27Vp98803atGiRYnlV69erQULFmjEiBEKDQ3VU089peuuu04//vijatWqJUnaunWr4uPjFRYWpvvuu09Vq1bVCy+8oC5duui///2vOnTo4LHPESNGKDIyUhMnTtSxY8fUq1cvff/993r77bf1xBNPqHbt2pKkyMhISX/O3kyYMEEDBw7U7bffrl9//VVPP/20EhIStHnzZkVEROjEiRPq0aOHcnNzNWrUKNWtW1c///yzPv74Yx0+fFjh4eGaO3eubr/9drVv317Dhw+XJDVq1KjYvv/xxx/q1q2bfvzxR40ePVoxMTGaO3euli1bVuLr9vnnn+vmm29Wt27d9Nhjj0mSvv32W33xxRcaM2aMEhISNHr0aD311FO6//77ddFFF0mS899XX31VISEhSklJUUhIiJYtW6aJEycqOztb06dP96jr999/V8+ePTVgwAANHDhQ7733nsaOHauWLVuqV69ekqS8vDxdc801Wrp0qW666SaNGTNGR44c0eeff65vvvnGeR3uuOMOvfrqq0pOTtbo0aO1e/duPfPMM9q8ebO++OKLEmd88vLy1LNnT1122WWaNm2aFi9erEmTJunUqVOaPHmyU6409cycOVOjRo1SSEiIHnjgAUlSnTp1FBERoRYtWmjlypUaPXq0pD/PUz8/Px06dEjbtm1T8+bNJUmrVq1SfHy8U++yZcvUq1cvtW3bVpMmTZK/v7/mzJmjrl27atWqVWrfvr0kKTMzU5dddpnz5ezIyEgtWrRIt912m7Kzs3X33Xd79Hvq1Kny9/fXv/71L2VlZWnatGkaPHiw1q9fX+xrNWDAgDOe9/ntfeedd3TXXXepdu3azpefn3zySfXt21eDBw/WiRMnNG/ePN1www36+OOP1bt37zMeI0kaNWqUatSooUmTJmnPnj2aOXOm7rrrLs2fP/+Mz/v888/1ww8/KDk5WXXr1tXWrVv14osvauvWrVq3bp38/Pw8yg8cOFBxcXFKS0vTpk2b9NJLLykqKsoZE5J0++2364033tCgQYPUqVMnLVu2rFR9uOiiizR58mRNnDhRw4cPd45zp06dnNeuNMf6zjvv1Hvvvae77rpLzZo108GDB7V69Wp9++23atOmjR544AFlZWXpp59+0hNPPCFJfAG7ItlOQfCuzz77zAQEBJiAgADTsWNHc99995lPP/3UnDhxolBZSSYwMNDjnfKWLVuMJPP000876/r3728CAwPNrl27nHX79u0zoaGhJiEhwVmX/y7siiuuKPSOfvr06YVmP4wxZs+ePSYgIMA88sgjHuu//vprU6VKFWf95s2bjaQi3w2eLjg4uMTZj3wzZ840ksw777zjrDt27Jhp3LhxiTMhY8aMMWFhYYX6ebp333230H7y5eTkFFp3xx13mOrVq5vjx4876/Lfpb3++uvOutzcXFO3bl1z3XXXOeteeeUVI8nMmDGj0H7zZw5WrVplJJk333zTY3v+zE/B9QUlJSUZSWbUqFEe++7du7cJDAw0v/76a5nrad68uencuXOhukaOHOkxw5GSkmISEhJMVFSUmTVrljHGmIMHDxo/Pz9nxsTtdpsmTZqYHj16eMyW5OTkmLi4OHPVVVc562677TYTHR1d6B3+TTfdZMLDw53jk/9u/KKLLjK5ublOuSeffNJIMl9//fUZX7Pizntj/hx//v7+ZuvWrYW2FTw/Tpw4YVq0aGG6du3qsb64mZDExESP1+Cee+4xAQEBzqxhcYo6L99++20jyaxcudJZlz8Tcuutt3qUvfbaa02tWrWcx+np6UaSGTFihEe5QYMGlTgTYowxGzZsKDT7YUzZjnV4eLgZOXLkGevp3bs3sx+W8MVUH3PVVVdp7dq16tu3r7Zs2aJp06apR48eqlevnj766KNC5RMTEz1mCy6++GKFhYXphx9+kPTnO9/PPvtM/fv31/nnn++Ui46O1qBBg7R69WplZ2d77HPYsGEKCAgoVXsXLFggt9utgQMH6rfffnOWunXrqkmTJlq+fLkkKTw8XJL06aefKicnp2wvSjH+85//KDo6Wtdff72zrnr16s4syplERETo2LFj+vzzz8+q7mrVqjn/f+TIEf3222+Kj49XTk6OvvvuO4+yISEhuuWWW5zHgYGBat++vXOMJOn9999X7dq1NWrUqEJ15b97fffddxUeHq6rrrrK47Vu27atQkJCnNe6JKdf1p0/k3DixAktWbLEa/XEx8crMzPT+TLwqlWrlJCQoPj4eK1atUrSn7MjxhjnHXJ6erp27NihQYMG6eDBg069x44dU7du3bRy5Uq53W4ZY/T++++rT58+MsZ4tLFHjx7KysrSpk2bPNqTnJyswMBAj/ZJ8jgGZ6Nz585q1qxZofWnnx+///67srKyFB8fX6hdxRk+fLjHrEV8fLzy8vK0d+/eMz7v9HqPHz+u3377TZdddpkkFVn3nXfe6fE4Pj5eBw8edP5N+M9//iNJzoxWvoIzTWVV2mMt/TlW169fr3379v2lOlE++DjGB7Vr104LFizQiRMntGXLFi1cuFBPPPGErr/+eqWnp3v8o3feeecVen6NGjX0+++/S5J+/fVX5eTk6MILLyxU7qKLLpLb7VZGRoYzPS5JcXFxpW7rjh07ZIxRkyZNitye//FAXFycUlJSNGPGDL355puKj49X3759dcsttzgBpaz27t2rxo0bF5piLqqvBY0YMULvvPOOevXqpXr16ql79+4aOHCgevbsWaq6t27dqgcffFDLli0rFOKysrI8HtevX79QG2vUqKH//e9/zuNdu3bpwgsvVJUqxQ/pHTt2KCsrS1FRUUVuL80Xl/39/T3CqCRdcMEFkuRcBeSNevL/yK9atUr169fX5s2bNWXKFEVGRurxxx93toWFhalVq1ZOvZKUlJRU7H6zsrJ08uRJHT58WC+++KJefPHFUrWx4DipUaOGJDnj5GwVN1Y+/vhjTZkyRenp6crNzXXWFzwPinO27T106JBSU1M1b968Qq9BwfOypHrCwsK0d+9e+fv7F/pYtDRj7ExKe6xr1KihadOmKSkpSQ0aNFDbtm119dVXa8iQIYXOY9hBCPFhgYGBateundq1a6cLLrhAycnJevfddzVp0iSnTHEzFsaYs6739HdTJXG73fLz89OiRYuKbMvpn83++9//1tChQ/Xhhx/qs88+0+jRo5WWlqZ169apfv36Z93esxEVFaX09HR9+umnWrRokRYtWqQ5c+ZoyJAheu2118743MOHD6tz584KCwvT5MmT1ahRIwUFBWnTpk0aO3as8w4un7eOkdvtVlRUlN58880it5/+XYW/whv1xMTEKC4uTitXrlTDhg1ljFHHjh0VGRmpMWPGaO/evVq1apU6deokf39/p15Jmj59ulq3bl3kfkNCQnTw4EFJ0i233FLsH7GLL77Y43F5jBOp6LGyatUq9e3bVwkJCXruuecUHR2tqlWras6cOXrrrbdKtd+zbe/AgQO1Zs0a3XvvvWrdurVCQkLkdrvVs2fPQuflX6nnryrtsZb+7FN8fLwWLlyozz77TNOnT9djjz2mBQsWON+pgj2EkL+JSy+9VJL0yy+/lOl5kZGRql69epH3yPjuu+/k7++vBg0alLif4t7BNWrUSMYYxcXFOe+oz6Rly5Zq2bKlHnzwQa1Zs0aXX365nn/+eU2ZMuWM9RQlNjZW33zzjYwxHs8r7f1AAgMD1adPH/Xp00dut1sjRozQCy+8oAkTJhQ5w5JvxYoVOnjwoBYsWKCEhARn/e7du0vd9oIaNWqk9evX6+TJk8V+ubRRo0ZasmSJLr/88jIFxdO53W798MMPHsfq+++/lyTnS5VlqedMxys+Pl4rV65UXFycWrdurdDQULVq1Urh4eFavHixNm3apNTUVI/+SVJYWJgSExOL3W9kZKRCQ0OVl5d3xnLeUJbzMd/777+voKAgffrppx6X4M6ZM8ebTSvk999/19KlS5WamqqJEyc66/NnHc5GbGys3G63M1OXr7Rj7Ez/bkglH+t80dHRGjFihEaMGKEDBw6oTZs2euSRR5wQcjbHCd7Bd0J8zPLly4t8F5L/2WxZp0EDAgLUvXt3ffjhhx433crMzNRbb72lK664QmFhYSXuJ/9eIQVv2jRgwAAFBAQoNTW1ULuNMc671uzsbJ06dcpje8uWLeXv7+8xXR0cHFzqG0NdffXV2rdvn9577z1nXU5OTrFT9KfLb1c+f39/591zfnuK63P+u8fT+3vixAk999xzpWp3Ua677jr99ttveuaZZwpty69n4MCBysvL08MPP1yozKlTp0r9up1ehzFGzzzzjKpWrapu3bqVuZ4zHa/4+Hjt2bNH8+fPdz6e8ff3V6dOnTRjxgydPHnS48qYtm3bqlGjRnr88cd19OjRQvv79ddfJf35+l933XV6//339c033xRbzhuKOwfOJCAgQH5+fsrLy3PW7dmzp9zvBFzUeSnpL93EK/+P/FNPPXVW+yzu9Svtsc7Lyyv0MVJUVJRiYmIK/btR1MdNKH/MhPiYUaNGKScnR9dee62aNm2qEydOaM2aNZo/f74aNmyo5OTkMu9zypQp+vzzz3XFFVdoxIgRqlKlil544QXl5uZq2rRppdpH27ZtJUkPPPCAbrrpJlWtWlV9+vRRo0aNNGXKFI0fP1579uxR//79FRoaqt27d2vhwoUaPny4/vWvf2nZsmW66667dMMNN+iCCy7QqVOnNHfuXOcPyun1LFmyRDNmzHCm9AteQpwv/46yQ4YM0caNGxUdHa25c+eqevXqJfbn9ttv16FDh9S1a1fVr19fe/fu1dNPP63WrVs7l+G2bt1aAQEBeuyxx5SVlSWXy6WuXbuqU6dOqlGjhpKSkjR69Gj5+flp7ty5f2kKe8iQIXr99deVkpKiL7/8UvHx8Tp27JiWLFmiESNGqF+/furcubPuuOMOpaWlKT09Xd27d1fVqlW1Y8cOvfvuu3ryySc9vqRblKCgIC1evFhJSUnq0KGDFi1apE8++UT333+/8zFLWepp27atZs2apSlTpqhx48aKiopS165dJf2/74Vs375djz76qNOGhIQELVq0SC6XS+3atXPW+/v766WXXlKvXr3UvHlzJScnq169evr555+1fPlyhYWF6f/+7/8k/XnJ7fLly9WhQwcNGzZMzZo106FDh7Rp0yYtWbJEhw4dOutjcbrizvsz3cCvd+/emjFjhnr27KlBgwbpwIEDevbZZ9W4cWOP7wF5W1hYmBISEjRt2jSdPHlS9erV02efffaXZuhat26tm2++Wc8995yysrLUqVMnLV26VDt37izV8xs1aqSIiAg9//zzCg0NVXBwsDp06KC4uLhSHesjR46ofv36uv7669WqVSuFhIRoyZIl2rBhg/7973879bRt21bz589XSkqK2rVrp5CQEPXp0+es+40yqNiLcVDeFi1aZG699VbTtGlTExISYgIDA03jxo3NqFGjTGZmpkdZ/f83Syqo4GV/xvx5s7IePXqYkJAQU716dXPllVeaNWvWeJTJvzxww4YNRbbt4YcfNvXq1TP+/v6FLlt8//33zRVXXGGCg4NNcHCwadq0qRk5cqTZvn27McaYH374wdx6662mUaNGJigoyNSsWdNceeWVZsmSJR51fPfddyYhIcFUq1atVDcr27t3r+nbt6+pXr26qV27thkzZkypblb23nvvme7duzs3ujrvvPPMHXfcYX755ReP/c+ePducf/75JiAgwGOfX3zxhbnsssucm4/lX0pdsN78m5UVVNTN03JycswDDzxg4uLiTNWqVU3dunXN9ddf73FptTHGvPjii6Zt27amWrVqJjQ01LRs2dLcd999Zt++fWd8rYq6WVmdOnXMpEmTTF5eXqHypaln//79pnfv3iY0NNS5WdnpoqKijCSPc3f16tVGkomPjy+ynZs3bzYDBgwwtWrVMi6Xy8TGxpqBAweapUuXepTLzMw0I0eONA0aNHBer27dupkXX3zRKZN/iW7BS8N3795d5KWjRSnuvC9u/BljzMsvv+zcdK5p06Zmzpw5zmWxpyvuEt2CYzC/H0VdLn66n376yVx77bUmIiLChIeHmxtuuMHs27ev0OW0+W3Jvyy7YP2nj+0//vjDjB492tSqVcsEBweX+mZl+T788EPnZm4FX/OSjnVubq659957TatWrZwbLbZq1co899xzHnUcPXrUDBo0yERERHCzsgrmZ0w5f4MIAACgCHwnBAAAWEEIAQAAVhBCAACAFYQQAABgBSEEAABYQQgBAABWnHM3K3O73dq3b59CQ0O5lS4AAJWEMUZHjhxRTEyM85tOJTnnQsi+fftK9VskAADg3JORkVHqHxU950JIaGiopD87UZrfJAEAAPZlZ2erQYMGzt/x0jjnQkj+RzBhYWGEEAAAKpmyfJWCL6YCAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCCEAAAAKwghAADAijKHkJUrV6pPnz6KiYmR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3LhxuummmyRJLVu21N69e5WWlqakpKRC5V0ul1wul7ebAQAAznFenwnJycmRv7/nbgMCAuR2u71dFQAAqMS8PhPSp08fPfLIIzrvvPPUvHlzbd68WTNmzNCtt97q7aoAAEAl5vUQ8vTTT2vChAkaMWKEDhw4oJiYGN1xxx2aOHGit6sCAACVmNdDSGhoqGbOnKmZM2d6e9cAAMCH8NsxAADACkIIAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCCEAAAAKwghAADACkIIAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCCEAAAAKwghAADACkIIAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCCEAAAAKwghAADACkIIAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCiXEPLzzz/rlltuUa1atVStWjW1bNlSX331VXlUBQAAKqkq3t7h77//rssvv1xXXnmlFi1apMjISO3YsUM1atTwdlUAAKAS83oIeeyxx9SgQQPNmTPHWRcXF+ftagAAQCXn9Y9jPvroI1166aW64YYbFBUVpUsuuUSzZ88utnxubq6ys7M9FgAA4Pu8PhPyww8/aNasWUpJSdH999+vDRs2aPTo0QoMDFRSUlKh8mlpaUpNTfV2MwDgb6/huE/Oqbr2TO3tlf2Uhrfa4y0VeSwqE6/PhLjdbrVp00aPPvqoLrnkEg0fPlzDhg3T888/X2T58ePHKysry1kyMjK83SQAAHAO8noIiY6OVrNmzTzWXXTRRfrxxx+LLO9yuRQWFuaxAAAA3+f1EHL55Zdr+/btHuu+//57xcbGersqAABQiXk9hNxzzz1at26dHn30Ue3cuVNvvfWWXnzxRY0cOdLbVQEAgErM6yGkXbt2Wrhwod5++221aNFCDz/8sGbOnKnBgwd7uyoAAFCJef3qGEm65pprdM0115THrgEAgI/gt2MAAIAVhBAAAGAFIQQAAFhBCAEAAFYQQgAAgBWEEAAAYAUhBAAAWEEIAQAAVhBCAACAFYQQAABgBSEEAABYQQgBAABWEEIAAIAVhBAAAGAFIQQAAFhBCAEAAFYQQgAAgBWEEAAAYAUhBAAAWEEIAQAAVhBCAACAFYQQAABgBSEEAABYUcV2A4DKpOG4T0oss2dq7wpoCUrjXDtepWmPL/u79x+FMRMCAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCCEAAAAKwghAADACkIIAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCCEAAAAKwghAADACkIIAACwotxDyNSpU+Xn56e77767vKsCAACVSLmGkA0bNuiFF17QxRdfXJ7VAACASqjcQsjRo0c1ePBgzZ49WzVq1CivagAAQCVVbiFk5MiR6t27txITE89YLjc3V9nZ2R4LAADwfVXKY6fz5s3Tpk2btGHDhhLLpqWlKTU1tTyaAaCSajjukxLL7Jnau9LVBcCT12dCMjIyNGbMGL355psKCgoqsfz48eOVlZXlLBkZGd5uEgAAOAd5fSZk48aNOnDggNq0aeOsy8vL08qVK/XMM88oNzdXAQEBzjaXyyWXy+XtZgAAgHOc10NIt27d9PXXX3usS05OVtOmTTV27FiPAAIAAP6+vB5CQkND1aJFC491wcHBqlWrVqH1AADg74s7pgIAACvK5eqYglasWFER1QAAgEqEmRAAAGAFIQQAAFhBCAEAAFYQQgAAgBWEEAAAYAUhBAAAWEEIAQAAVhBCAACAFYQQAABgBSEEAABYQQgBAABWEEIAAIAVhBAAAGAFIQQAAFhBCAEAAFYQQgAAgBWEEAAAYAUhBAAAWEEIAQAAVhBCAACAFYQQAABgBSEEAABYUcV2A/D31XDcJ17Zz56pvb2yn7+z0hyL0rzO3trPucZb5yoAT8yEAAAAKwghAADACkIIAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCCEAAAAKwghAADACkIIAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCCEAAAAK7weQtLS0tSuXTuFhoYqKipK/fv31/bt271dDQAAqOS8HkL++9//auTI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kpIKDYjT+fJx7devn+natavHusp4XI0x5pJLLjEPPvigMca3x6sxnn0tiq+MV2MK99VXx6sxJR/XyjxeT506ZTp16mReeumlQsewIsdrhXwcc+LECW3cuFGJiYnOOn9/fyUmJmrt2rWl2kdOTo5OnjypmjVrSpJ2796t/fv3e+wzPDxcHTp0cPa5du1aRURE6NJLL3XKJCYmyt/fX+vXr/dG1wopj74WJSsrS35+foV+7G/q1KmqVauWLrnkEk2fPl2nTp06q36URnn2dcWKFYqKitKFF16of/7znzp48KCzzVePa2Zmpj755BPddttthbZVpuNqjNHSpUu1fft2JSQkSPLd8VpUX4viC+P1TH31tfFamuNa2cfr5MmTFRUVVWT7K3K8lstt2wv67bfflJeXV+i27XXq1NF3331Xqn2MHTtWMTExzouyf/9+Zx8F95m/bf/+/YqKivLYXqVKFdWsWdMp423l0deCjh8/rrFjx+rmm2/2+LXD0aNHq02bNqpZs6bWrFmj8ePH65dfftGMGTPOvkNnUF597dmzpwYMGKC4uDjt2rVL999/v3r16qW1a9cqICDAZ4/ra6+9ptDQUA0YMMBjfWU5rllZWapXr55yc3MVEBCg5557TldddZUk3xuvZ+prQZV9vJbUV18ar2U5rpV5vK5evVovv/yy0tPTi9xekeO1QkLIXzV16lTNmzdPK1asUFBQkO3mlKuS+nry5EkNHDhQxhjNmjXLY1tKSorz/xdffLECAwN1xx13KC0t7Zz87YPi+nrTTTc5/9+yZUtdfPHFatSokVasWKFu3brZaOpfVppz+JVXXtHgwYMLba8sxzU0NFTp6ek6evSoli5dqpSUFJ1//vnq0qWL7aZ5XWn76gvjtaS++tJ4Lcs5XFnH65EjR/SPf/xDs2fPVu3atW03p2JCSO3atRUQEKDMzEyP9ZmZmapbt+4Zn/v4449r6tSpWrJkiS6++GJnff7zMjMzFR0d7bHP1q1bO2UOHDjgsb9Tp07p0KFDJdZ7tsqjr/ny/0Hbu3evli1b5vGuqigdOnTQqVOntGfPHl144YVl70wJyrOvpzv//PNVu3Zt7dy5U926dfO54ypJq1at0vbt2zV//vwS23KuHld/f381btxYktS6dWt9++23SktLU5cuXXxuvJ6pr/l8ZbyWpq+nq8zjtbR9rczjddeuXdqzZ4/69OnjrHO73ZL+nMnYvn17hY7XCvlOSGBgoNq2baulS5c669xut5YuXaqOHTsW+7xp06bp4Ycf1uLFiz0+d5KkuLg41a1b12Of2dnZWr9+vbPPjh076vDhw9q4caNTZtmyZXK73erQoYO3uuehPPoq/b9/0Hbs2KElS5aoVq1aJbYlPT1d/v7+habMvKW8+lrQTz/9pIMHDzqDwZeOa76XX35Zbdu2VatWrUpsy7l6XAtyu93Kzc2V5HvjtaDT+yr51ngtqGBfC6rM47Wg4vpamcdr06ZN9fXXXys9Pd1Z+vbtqyuvvFLp6elq0KBBxY7XUn+F9S+aN2+ecblc5tVXXzXbtm0zw4cPNxEREWb//v3GGGP+8Y9/mHHjxjnlp06dagIDA817773ncanTkSNHPMpERESYDz/80Pzvf/8z/fr1K/ISoksuucSsX7/erF692jRp0qRCLg3zZl9PnDhh+vbta+rXr2/S09M9yuTm5hpjjFmzZo154oknTHp6utm1a5d54403TGRkpBkyZEil6uuRI0fMv/71L7N27Vqze/dus2TJEtOmTRvTpEkTc/z4cWc/vnBc82VlZZnq1aubWbNmFaqzshzXRx991Hz22Wdm165dZtu2bebxxx83VapUMbNnz3bK+Mp4LamvvjReS+qrL43X0pzDxvjGeC2oqCucKmq8VlgIMcaYp59+2px33nkmMDDQtG/f3qxbt87Z1rlzZ5OUlOQ8jo2NNZIKLZMmTXLKuN1uM2HCBFOnTh3jcrlMt27dzPbt2z3qPHjwoLn55ptNSEiICQsLM8nJyYX+CJQHb/Z19+7dRW6XZJYvX26MMWbjxo2mQ4cOJjw83AQFBZmLLrrIPProox7/EFSGvubk5Jju3bubyMhIU7VqVRMbG2uGDRvmDKZ8vnBc873wwgumWrVq5vDhw4XqqyzH9YEHHjCNGzc2QUFBpkaNGqZjx45m3rx5HvvzlfFaUl99abyW1FdfGq+lOYeN8Y3xWlBRIaSixqufMcaUft4EAADAO/jtGAAAYAUhBAAAWEEIAQAAVhBCAACAFYQQAABgBSEEAABYQQgBAABWEEIAAIAVhBAAAGAFIQQAAFhBCAEAAFb8f4eiNjugT9KdAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "train_2, test_2, sim_2 = get_hi_split(drd2_hi, threshold=0.4, seed=31662, cutoff=0.55)\n",
    "print('Train: ' + str(len(train_2)) + ' test: ' + str(len(test_2)))\n",
    "plt.hist(sim_2, bins=50)\n",
    "plt.title('Shortest distance between train and test')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train: 5013 valid: 70\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Shortest distance between train and test')"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAhcAAAGzCAYAAACcvDUtAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA0f0lEQVR4nO3dd3hUZd7/8U8KmUAqJYGEEiKoSF+qoAlIZxGwomIJuLYlFOVZVtEVjKIJqAiLioIuuKwIFoqPLkWawAKKQFgBpSglioKCJBSdQOb+/eEv8zCkkAn3hEx4v65rLp2T+5z7+50zc/jMmRZgjDECAACwJPBiFwAAACoWwgUAALCKcAEAAKwiXAAAAKsIFwAAwCrCBQAAsIpwAQAArCJcAAAAqwgXAADAKsJFBRUQEKChQ4de7DLKnVWrVikgIECrVq1yLxs0aJDq169/0WoqDwYNGqTw8PCLXQbOUr9+fQ0aNOhil1EqAQEBeuqppy52GbiICBd+5ssvv9Qtt9yihIQEhYaGqnbt2urevbumTJly0Wpat26dnnrqKR07dsyn8zz33HNasGCBT+coqR07duipp57Svn37LnYp5darr76qmTNnXuwyfKas7vcV1cGDB/XUU08pMzPTp/PMnj1bkyZN8ukcKIhw4UfWrVunNm3aaOvWrbr//vv18ssv67777lNgYKAmT558UetKS0vz23Axffp07dy506t1duzYobS0NMJFMS6FcOHL+/3OnTs1ffp0n2y7PDh48KDS0tIIFxVU8MUuACX37LPPKioqShs3blR0dLTH3w4fPlzm9Zw8eVJhYWFlPq9tlSpVutgloIJzuVzKzc1VaGhoiddxOBw+rAjwMQO/ceWVV5rOnTuXaKwkk5qaaubPn2+aNGliQkJCTOPGjc2iRYsKjN28ebPp1auXiYiIMGFhYaZLly5m/fr1HmNmzJhhJJlVq1aZP//5zyYmJsZER0ebsWPHGkkFLnv37nWvO2vWLNOqVSsTGhpqqlatam677TZz4MABj+3v2rXL3HTTTaZmzZrG4XCY2rVrm9tuu80cO3bM3c+5l5SUlGJvg6ysLNO/f39TpUoVExMTYx5++GGzePFiI8msXLnSPS4lJcUkJCR4rPvOO++YVq1amfDwcBMREWGaNm1qJk2a5HFbnHvJ3+aCBQvMH//4RxMXF2dCQkLMZZddZp5++mlz5swZjzk6depkmjRpYrZv3246d+5sKleubOLj48348eML9PLrr7+asWPHmssvv9w4HA5Tq1Ytc+ONN5o9e/a4x+Tl5ZmXXnrJNG7c2DgcDhMbG2seeOABc/To0WJvp/zbICwszHzzzTemR48epkqVKiYuLs6kpaUZl8vlMbYk8yQkJBS4fTp16mR++eUXExgYaCZPnuwe+9NPP5mAgABTrVo1j7keeughU7NmTY+5N2zYYHr27GkiIyNN5cqVTXJyslm7dm2Bfr777jszePBgExsb677vv/nmmx5jVq5caSSZuXPnmnHjxpnatWsbh8NhunTpYnbv3l3s7XW++33+4+9f//qXady4sQkODjbz5883xhjz/PPPmw4dOphq1aqZ0NBQ06pVK/Pee+8VmCMhIcHjPp5/v1u7dq155JFHTI0aNUyVKlXMDTfcYA4fPlxsvcYYs3XrVpOSkmISExONw+EwNWvWNIMHDzY///xzob3t3r3bpKSkmKioKBMZGWkGDRpkTp486TH2t99+Mw8//LCpUaOGCQ8PN3379jVZWVlGkhk7dmyRteTf9udeZsyY4R5Tkn2dk5NjRowYYRISEkxISIiJiYkx3bp1M5s2bTLG/P4YO3eOcx/r8A3OXPiRhIQErV+/Xtu2bVPTpk3PO37t2rWaN2+ehgwZooiICP3973/XzTffrAMHDqh69eqSpO3btyspKUmRkZH661//qkqVKun1119X586d9emnn6p9+/Ye2xwyZIhiYmI0ZswYnTx5Ur1799auXbv0zjvv6KWXXlKNGjUkSTExMZJ+P9vy5JNPasCAAbrvvvv0008/acqUKUpOTtaWLVsUHR2t3Nxc9ezZU06nU8OGDVOtWrX0/fff66OPPtKxY8cUFRWlWbNm6b777lO7du30wAMPSJIaNGhQZO+//vqrunbtqgMHDmj48OGKj4/XrFmztGLFivPebp988onuuOMOde3aVePHj5ckffXVV/rPf/6jESNGKDk5WcOHD9ff//53Pf7447rqqqskyf3fmTNnKjw8XCNHjlR4eLhWrFihMWPGKCcnR88//7zHXL/88ot69eqlm266SQMGDND777+vRx99VM2aNVPv3r0lSXl5ebr++uu1fPly3X777RoxYoSOHz+uTz75RNu2bXPfDg8++KBmzpypwYMHa/jw4dq7d69efvllbdmyRf/5z3/Oe4YmLy9PvXr10tVXX60JEyZo8eLFGjt2rM6cOaOnn37aPa4k80yaNEnDhg1TeHi4nnjiCUlSzZo1FR0draZNm2r16tUaPny4pN/vpwEBATp69Kh27NihJk2aSJLWrFmjpKQk97wrVqxQ79691bp1a40dO1aBgYGaMWOGunTpojVr1qhdu3aSpEOHDunqq692v6k5JiZGixYt0p/+9Cfl5OTo4Ycf9ug7IyNDgYGB+stf/qLs7GxNmDBBd955pz777LMib6ubbrqp2Pt9fr3vvvuuhg4dqho1arjfNDx58mT169dPd955p3JzczVnzhzdeuut+uijj9SnT59i95EkDRs2TFWrVtXYsWO1b98+TZo0SUOHDtXcuXOLXe+TTz7Rt99+q8GDB6tWrVravn27pk2bpu3bt2vDhg0KCAjwGD9gwAAlJiYqPT1dmzdv1htvvKHY2Fj3Y0KS7rvvPv3rX//SwIED1bFjR61YsaJEPVx11VV6+umnNWbMGD3wwAPu/dyxY0f3bVeSff3QQw/p/fff19ChQ9W4cWMdOXJEa9eu1VdffaVWrVrpiSeeUHZ2tr777ju99NJLksQbl8vKxU43KLmlS5eaoKAgExQUZDp06GD++te/miVLlpjc3NwCYyWZkJAQj2e2W7duNZLMlClT3MtuuOEGExISYr755hv3soMHD5qIiAiTnJzsXpb/rOnaa68t8Az8+eefL3C2whhj9u3bZ4KCgsyzzz7rsfzLL780wcHB7uVbtmwxkgp99na2sLCw856tyDdp0iQjybz77rvuZSdPnjQNGzY875mLESNGmMjIyAJ9nu29994rsJ18p06dKrDswQcfNFWqVDG//fabe1n+s6p//vOf7mVOp9PUqlXL3Hzzze5l//jHP4wkM3HixALbzX+mv2bNGiPJvP322x5/zz9Tc+7yc6WkpBhJZtiwYR7b7tOnjwkJCTE//fST1/M0adLEdOrUqcBcqampHmckRo4caZKTk01sbKyZOnWqMcaYI0eOmICAAPcZDpfLZS6//HLTs2dPj7Mbp06dMomJiaZ79+7uZX/6059MXFxcgWfkt99+u4mKinLvn/xnz1dddZVxOp3ucZMnTzaSzJdfflnsbVbU/d6Y3x9/gYGBZvv27QX+du79Izc31zRt2tR06dLFY3lRZy66devmcRs88sgjJigoyH2WryiF3S/feecdI8msXr3avSz/zMW9997rMfbGG2801atXd1/PzMw0ksyQIUM8xg0cOPC8Zy6MMWbjxo0FzlYY492+joqKMqmpqcXO06dPH85WXAS8odOPdO/eXevXr1e/fv20detWTZgwQT179lTt2rX14YcfFhjfrVs3j2f3zZs3V2RkpL799ltJvz9TXbp0qW644QZddtll7nFxcXEaOHCg1q5dq5ycHI9t3n///QoKCipRvfPmzZPL5dKAAQP0888/uy+1atXS5ZdfrpUrV0qSoqKiJElLlizRqVOnvLtRivDvf/9bcXFxuuWWW9zLqlSp4j7rUZzo6GidPHlSn3zySanmrly5svv/jx8/rp9//llJSUk6deqUvv76a4+x4eHhuuuuu9zXQ0JC1K5dO/c+kqQPPvhANWrU0LBhwwrMlf9s87333lNUVJS6d+/ucVu3bt1a4eHh7tv6fM7++HL+M//c3FwtW7bM2jxJSUk6dOiQ+020a9asUXJyspKSkrRmzRpJv5/NMMa4n9FmZmZq9+7dGjhwoI4cOeKe9+TJk+ratatWr14tl8slY4w++OAD9e3bV8YYjxp79uyp7Oxsbd682aOewYMHKyQkxKM+SR77oDQ6deqkxo0bF1h+9v3jl19+UXZ2tpKSkgrUVZQHHnjA4yxDUlKS8vLytH///mLXO3ve3377TT///LOuvvpqSSp07oceesjjelJSko4cOeI+Jvz73/+WJPcZqHznnhnyVkn3tfT7Y/Wzzz7TwYMHL2hO2MfLIn6mbdu2mjdvnnJzc7V161bNnz9fL730km655RZlZmZ6HMzq1atXYP2qVavql19+kST99NNPOnXqlK688soC46666iq5XC5lZWW5T1NLUmJiYolr3b17t4wxuvzyywv9e/5p+sTERI0cOVITJ07U22+/raSkJPXr10933XWXO3h4a//+/WrYsGGBU72F9XquIUOG6N1331Xv3r1Vu3Zt9ejRQwMGDFCvXr1KNPf27dv1t7/9TStWrCgQzrKzsz2u16lTp0CNVatW1X//+1/39W+++UZXXnmlgoOLfrju3r1b2dnZio2NLfTvJXnDb2BgoEfIlKQrrrhCktyfirExT/4/3mvWrFGdOnW0ZcsWjRs3TjExMXrhhRfcf4uMjFSLFi3c80pSSkpKkdvNzs7W6dOn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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "train_3, test_3, sim_3 = get_hi_split(drd2_hi, threshold=0.4, seed=228, cutoff=0.55)\n",
    "print('Train: ' + str(len(train_3)) + ' valid: ' + str(len(test_3)))\n",
    "plt.hist(sim_3, bins=50)\n",
    "plt.title('Shortest distance between train and test')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib_venn._common.VennDiagram at 0x7fab4963a350>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "venn3([\n",
    "    set(test_1['smiles'].tolist()),\n",
    "    set(test_2['smiles'].tolist()),\n",
    "    set(test_3['smiles'].tolist()),\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_1.to_csv('../../data/hi/drd2_greedy/train_1.csv')\n",
    "train_2.to_csv('../../data/hi/drd2_greedy/train_2.csv')\n",
    "train_3.to_csv('../../data/hi/drd2_greedy/train_3.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_1.to_csv('../../data/hi/drd2_greedy/test_1.csv')\n",
    "test_2.to_csv('../../data/hi/drd2_greedy/test_2.csv')\n",
    "test_3.to_csv('../../data/hi/drd2_greedy/test_3.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gero_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.9"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
