{
 "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>CCC1=[O+][Cu-3]2([O+]=C(CC)C1)[O+]=C(CC)CC(CC)...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>C(=Cc1ccccc1)C1=[O+][Cu-3]2([O+]=C(C=Cc3ccccc3...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>CC(=O)N1c2ccccc2Sc2c1ccc1ccccc21</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Nc1ccc(C=Cc2ccc(N)cc2S(=O)(=O)O)c(S(=O)(=O)O)c1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>O=S(=O)(O)CCS(=O)(=O)O</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41122</th>\n",
       "      <td>CCC1CCC2c3c([nH]c4ccc(C)cc34)C3C(=O)N(N(C)C)C(...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41123</th>\n",
       "      <td>Cc1ccc2[nH]c3c(c2c1)C1CCC(C(C)(C)C)CC1C1C(=O)N...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41124</th>\n",
       "      <td>Cc1ccc(N2C(=O)C3c4[nH]c5ccccc5c4C4CCC(C(C)(C)C...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41125</th>\n",
       "      <td>Cc1cccc(N2C(=O)C3c4[nH]c5ccccc5c4C4CCC(C(C)(C)...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41126</th>\n",
       "      <td>CCCCCC=C(c1cc(Cl)c(OC)c(-c2nc(C)no2)c1)c1cc(Cl...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>41127 rows × 2 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                  smiles  value\n",
       "0      CCC1=[O+][Cu-3]2([O+]=C(CC)C1)[O+]=C(CC)CC(CC)...      0\n",
       "1      C(=Cc1ccccc1)C1=[O+][Cu-3]2([O+]=C(C=Cc3ccccc3...      0\n",
       "2                       CC(=O)N1c2ccccc2Sc2c1ccc1ccccc21      0\n",
       "3        Nc1ccc(C=Cc2ccc(N)cc2S(=O)(=O)O)c(S(=O)(=O)O)c1      0\n",
       "4                                 O=S(=O)(O)CCS(=O)(=O)O      0\n",
       "...                                                  ...    ...\n",
       "41122  CCC1CCC2c3c([nH]c4ccc(C)cc34)C3C(=O)N(N(C)C)C(...      0\n",
       "41123  Cc1ccc2[nH]c3c(c2c1)C1CCC(C(C)(C)C)CC1C1C(=O)N...      0\n",
       "41124  Cc1ccc(N2C(=O)C3c4[nH]c5ccccc5c4C4CCC(C(C)(C)C...      0\n",
       "41125  Cc1cccc(N2C(=O)C3c4[nH]c5ccccc5c4C4CCC(C(C)(C)...      0\n",
       "41126  CCCCCC=C(c1cc(Cl)c(OC)c(-c2nc(C)no2)c1)c1cc(Cl...      0\n",
       "\n",
       "[41127 rows x 2 columns]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "hiv = pd.read_csv('../../data/raw/HIV.csv')\n",
    "hiv['value'] = hiv['HIV_active']\n",
    "hiv = hiv.drop(labels=['activity', 'HIV_active'], axis=1)\n",
    "hiv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.03508643956524911"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "hiv['value'].mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[12:55:41] WARNING: not removing hydrogen atom without neighbors\n",
      "[12:55:41] WARNING: not removing hydrogen atom without neighbors\n",
      "[12:58:43] WARNING: not removing hydrogen atom without neighbors\n",
      "[12:58:43] WARNING: not removing hydrogen atom without neighbors\n",
      "[12:59:26] WARNING: not removing hydrogen atom without neighbors\n",
      "[12:59:26] WARNING: not removing hydrogen atom without neighbors\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train: 32901 test: 2375\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": "iVBORw0KGgoAAAANSUhEUgAAAigAAAGzCAYAAAAFROyYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA5c0lEQVR4nO3df3yPdf////s29hr2yzDbNDMUkh9RLZ1tfi2MN4mS6GwkKr/KPr0rZ8KcznOiU0rUWWdx1kmk0HnWSfkZMiqsHyonGurE8iMbU8P2/P7Rd8fbyzY2Xi97bm7Xy+W42Os4nq/jeBzP1/Gy+56v4zhePsYYIwAAAIv4lncBAAAA5yKgAAAA6xBQAACAdQgoAADAOgQUAABgHQIKAACwDgEFAABYh4ACAACsQ0ABAADWIaDgvHx8fDRy5MjyLsM6a9eulY+Pj9auXevMGzRokBo0aFBuNdlg0KBBCgwMLO8ycJYGDRpo0KBB5V3GRfHx8dHEiRPLuwyUEwLKFeqrr77SnXfeqZiYGAUEBKhevXq67bbbNHPmzHKraePGjZo4caKOHTvm1e38+c9/1tKlS726jdL65ptvNHHiRO3Zs6e8S7HW7NmzNXfu3PIuw2su13FfWe3fv18TJ05URkaGV7czf/58zZgxw6vbgDsCyhVo48aNuuGGG/TFF19o6NChevHFF/XAAw/I19dXzz//fLnWlZqaWmEDyquvvqodO3aU6TnffPONUlNTCSjncSUEFG8e9zt27NCrr77qlXXbYP/+/UpNTSWgVEJVyrsAXH5/+tOfFBISos8++0yhoaFuy3766afLXk9ubq5q1Khx2bfraVWrVi3vElDJFRQU6NSpUwoICCj1c1wulxcrArzI4IrTpEkT06FDh1K1lWRGjBhhlixZYpo3b278/f3Ntddea5YtW1ak7datW023bt1MUFCQqVGjhunUqZNJT093azNnzhwjyaxdu9Y8/PDDpk6dOiY0NNRMmDDBSCoyZWZmOs998803TZs2bUxAQICpWbOmufvuu82+ffvc1v+f//zH9OnTx9StW9e4XC5Tr149c/fdd5tjx445+3PulJycfN4++OGHH8ztt99uqlevburUqWMeffRRs3z5ciPJrFmzxmmXnJxsYmJi3J771ltvmTZt2pjAwEATFBRkrrvuOjNjxgy3vjh3Klzn0qVLTffu3U1kZKTx9/c3DRs2NJMmTTJnzpxx20b79u1N8+bNzfbt202HDh1MtWrVTFRUlHnmmWeK7Msvv/xiJkyYYK6++mrjcrlMRESEueOOO8yuXbucNvn5+ea5554z1157rXG5XCY8PNwMGzbMHD169Lz9VNgHNWrUMLt37zZdunQx1atXN5GRkSY1NdUUFBS4tS3NdmJiYor0T/v27c3PP/9sfH19zfPPP++0PXTokPHx8TFhYWFu23rooYdM3bp13ba9adMm07VrVxMcHGyqVatmEhISzIYNG4rsz48//mgGDx5swsPDnWP/tddec2uzZs0aI8ksXLjQTJ482dSrV8+4XC7TqVMns3PnzvP214WO+8L33z/+8Q9z7bXXmipVqpglS5YYY4yZNm2aadeunQkLCzMBAQGmTZs2ZtGiRUW2ERMT43aMFx53GzZsMGPGjDG1a9c21atXN7179zY//fTTees1xpgvvvjCJCcnm9jYWONyuUzdunXN4MGDzeHDh4vdt507d5rk5GQTEhJigoODzaBBg0xubq5b219//dU8+uijpnbt2iYwMND07NnT/PDDD0aSmTBhQom1FPb9udOcOXOcNqV5rXNycswjjzxiYmJijL+/v6lTp45JTEw0W7ZsMcb89h47dxvnvtfheYygXIFiYmKUnp6ur7/+Wtddd90F22/YsEGLFy/W8OHDFRQUpBdeeEF9+/bVvn37VKtWLUnS9u3bFR8fr+DgYD3++OOqWrWq/vrXv6pDhw76+OOPFRcX57bO4cOHq06dOho/frxyc3OVlJSk//znP3rrrbf03HPPqXbt2pKkOnXqSPpt1Ofpp59Wv3799MADD+jQoUOaOXOmEhIStG3bNoWGhurUqVPq2rWr8vLyNGrUKEVEROi///2v3n//fR07dkwhISF688039cADD+imm27SsGHDJEmNGjUqcd9/+eUXde7cWfv27dPo0aMVFRWlN998U6tXr75gv61YsUL33HOPOnfurGeeeUaS9O233+qTTz7RI488ooSEBI0ePVovvPCC/vCHP6hZs2aS5Pw7d+5cBQYGKiUlRYGBgVq9erXGjx+vnJwcTZs2zW1bP//8s7p166Y+ffqoX79+euedd/TEE0+oRYsWSkpKkiTl5+frf/7nf7Rq1Sr1799fjzzyiI4fP64VK1bo66+/dvrhwQcf1Ny5czV48GCNHj1amZmZevHFF7Vt2zZ98sknFxwpys/PV7du3XTzzTdr6tSpWr58uSZMmKAzZ85o0qRJTrvSbGfGjBkaNWqUAgMD9dRTT0mS6tatq9DQUF133XVat26dRo8eLem349THx0dHjx7VN998o+bNm0uS1q9fr/j4eGe7q1evVlJSktq2basJEybI19dXc+bMUadOnbR+/XrddNNNkqSsrCzdfPPNzoniderU0bJlyzRkyBDl5OTo0UcfddvvKVOmyNfXV4899piys7M1depUDRw4UJs3by6xr/r06XPe476w3rffflsjR45U7dq1nROxn3/+efXq1UsDBw7UqVOntGDBAt111116//331aNHj/O+RpI0atQo1axZUxMmTNCePXs0Y8YMjRw5UgsXLjzv81asWKHvv/9egwcPVkREhLZv365XXnlF27dv16ZNm+Tj4+PWvl+/foqNjVVaWpq2bt2qv/3tbwoPD3feE5L0wAMP6B//+IcGDBigW265RatXry7VPjRr1kyTJk3S+PHjNWzYMOd1vuWWW5y+K81r/dBDD+mdd97RyJEjde211+rIkSPasGGDvv32W7Vp00ZPPfWUsrOz9eOPP+q5556TJE4GvxzKOyHh8vvoo4+Mn5+f8fPzM+3atTOPP/64+fDDD82pU6eKtJVk/P393f7C/uKLL4wkM3PmTGde7969jb+/v9m9e7czb//+/SYoKMgkJCQ48wr/erv11luLjARMmzatyKiJMcbs2bPH+Pn5mT/96U9u87/66itTpUoVZ/62bduMpGL/ijxbjRo1LjhqUmjGjBlGknn77bedebm5uaZx48YXHEF55JFHTHBwcJH9PNuiRYuKrKfQyZMni8x78MEHTfXq1c2vv/7qzCv86+6NN95w5uXl5ZmIiAjTt29fZ97rr79uJJnp06cXWW/hiMP69euNJDNv3jy35YUjRufOP1dycrKRZEaNGuW27h49ehh/f39z6NChMm+nefPmpn379kW2NWLECLeRkZSUFJOQkGDCw8PNSy+9ZIwx5siRI8bHx8cZaSkoKDBXX3216dq1q9soy8mTJ01sbKy57bbbnHlDhgwxkZGRRUYG+vfvb0JCQpzXp/Cv+GbNmpm8vDyn3fPPP28kma+++uq8fVbScW/Mb+8/X19fs3379iLLzj0+Tp06Za677jrTqVMnt/kljaAkJia69cGYMWOMn5+fM9pYkuKOy7feestIMuvWrXPmFY6g3H///W5t77jjDlOrVi3ncUZGhpFkhg8f7tZuwIABFxxBMcaYzz77rMioiTFle61DQkLMiBEjzrudHj16MGpymXGS7BXotttuU3p6unr16qUvvvhCU6dOVdeuXVWvXj3985//LNI+MTHRbZShZcuWCg4O1vfffy/pt7+YP/roI/Xu3VsNGzZ02kVGRmrAgAHasGGDcnJy3NY5dOhQ+fn5larexYsXq6CgQP369dPhw4edKSIiQldffbXWrFkjSQoJCZEkffjhhzp58mTZOqUE//73vxUZGak777zTmVe9enVn9OV8QkNDlZubqxUrVlzUtqtVq+b8fPz4cR0+fFjx8fE6efKkvvvuO7e2gYGBuvfee53H/v7+uummm5zXSJLeffdd1a5dW6NGjSqyrcK/ehctWqSQkBDddtttbn3dtm1bBQYGOn19IWdfml44AnHq1CmtXLnSY9uJj49XVlaWc2Ly+vXrlZCQoPj4eK1fv17Sb6MqxhjnL+uMjAzt3LlTAwYM0JEjR5zt5ubmqnPnzlq3bp0KCgpkjNG7776rnj17yhjjVmPXrl2VnZ2trVu3utUzePBg+fv7u9Unye01uBjt27fXtddeW2T+2cfHzz//rOzsbMXHxxepqyTDhg1zG+2Ij49Xfn6+9u7de97nnb3dX3/9VYcPH9bNN98sScVu+6GHHnJ7HB8fryNHjjj/J/z73/+WJGckrNC5I1RlVdrXWvrtvbp582bt37//krYJz+IjnivUjTfeqMWLF+vUqVP64osvtGTJEj333HO68847lZGR4fYfYv369Ys8v2bNmvr5558lSYcOHdLJkyfVpEmTIu2aNWumgoIC/fDDD86QuyTFxsaWutadO3fKGKOrr7662OWFHznExsYqJSVF06dP17x58xQfH69evXrp3nvvdcJLWe3du1eNGzcuMmxd3L6ea/jw4Xr77beVlJSkevXqqUuXLurXr5+6detWqm1v375d48aN0+rVq4sEvOzsbLfHV111VZEaa9asqS+//NJ5vHv3bjVp0kRVqpT8tt+5c6eys7MVHh5e7PLSnETt6+vrFlQl6ZprrpEk52olT2ynMACsX79eV111lbZt26bJkyerTp06evbZZ51lwcHBatWqlbNdSUpOTi5xvdnZ2Tp9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AADWIaAAAADrEFAAAIB1CCgAAMA6BBQAAGCdKuVdAAAAktTgyQ8u2GbPlB6XoRLYgBEUAABgHUZQAAAVRmlGWVA5MIICAACsQ0ABAADWIaAAAADrEFAAAIB1CCgAAMA6BBQAAGAdAgoAALAOAQUAAFinzAFl3bp16tmzp6KiouTj46OlS5e6LTfGaPz48YqMjFS1atWUmJionTt3urU5evSoBg4cqODgYIWGhmrIkCE6ceLEJe0IAACoPMocUHJzc9WqVSvNmjWr2OVTp07VCy+8oJdfflmbN29WjRo11LVrV/36669Om4EDB2r79u1asWKF3n//fa1bt07Dhg27+L0AAACVSplvdZ+UlKSkpKRilxljNGPGDI0bN0633367JOmNN95Q3bp1tXTpUvXv31/ffvutli9frs8++0w33HCDJGnmzJnq3r27nn32WUVFRV3C7gAAgMrAo+egZGZm6uDBg0pMTHTmhYSEKC4uTunp6ZKk9PR0hYaGOuFEkhITE+Xr66vNmzcXu968vDzl5OS4TQAAoPLyaEA5ePCgJKlu3bpu8+vWressO3jwoMLDw92WV6lSRWFhYU6bc6WlpSkkJMSZoqOjPVk2AACwTIW4imfs2LHKzs52ph9++KG8SwIAAF7k0YASEREhScrKynKbn5WV5SyLiIjQTz/95Lb8zJkzOnr0qNPmXC6XS8HBwW4TAACovDwaUGJjYxUREaFVq1Y583JycrR582a1a9dOktSuXTsdO3ZMW7ZscdqsXr1aBQUFiouL82Q5AACggirzVTwnTpzQrl27nMeZmZnKyMhQWFiY6tevr0cffVSTJ0/W1VdfrdjYWD399NOKiopS7969JUnNmjVTt27dNHToUL388ss6ffq0Ro4cqf79+3MFDwAAkHQRAeXzzz9Xx44dnccpKSmSpOTkZM2dO1ePP/64cnNzNWzYMB07dky33nqrli9froCAAOc58+bN08iRI9W5c2f5+vqqb9++euGFFzywOwAAoDLwMcaY8i6irHJychQSEqLs7GzORwGACqDBkx+Udwkooz1Tenh8nWX5/V0hruIBAABXFgIKAACwDgEFAABYh4ACAACsQ0ABAADWIaAAAADrEFAAAIB1CCgAAMA6BBQAAGAdAgoAALAOAQUAAFiHgAIAAKxDQAEAANYhoAAAAOsQUAAAgHUIKAAAwDoE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7VqTmZlpPvnkE5OYmGhq165tfvrpp8u+f5dLWftxypQpxt/f37zzzjtulxgeP37crU1oaKh57733zJdffmluv/32K+ZyTk/25fHjx81jjz1m0tPTTWZmplm5cqVp06aNufrqq82vv/5aLvt4uZS1L//85z+bjz76yOzevdt888035tlnnzVVqlQxr776qtOG49IzfXmlHpdl7cdzFXflkzeOSQKKJWbOnGnq169v/P39zU033WQ2bdrkLGvfvr1JTk52HmdmZhpJRab27ds7be6++24TGRlp/P39Tb169czdd99tdu3adRn3qHyUpR9jYmKK7ccJEyY4bQoKCszTTz9t6tata1wul+ncubPZsWPHZdyj8uPJvjx58qTp0qWLqVOnjqlataqJiYkxQ4cOdf5DrOzK0pdPPfWUady4sQkICDA1a9Y07dq1MwsWLHBbH8elZ/rySj4uy9KP5youoHjjmPQxxpiLH38BAADwPM5BAQAA1iGgAAAA6xBQAACAdQgoAADAOgQUAABgHQIKAACwDgEFAABYh4ACAACsQ0ABAADWIaAAAADrEFAAAIB1/j97GX4nwmX2vAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "train_1, test_1, sim_1 = get_hi_split(hiv, 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": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[12:59:46] WARNING: not removing hydrogen atom without neighbors\n",
      "[12:59:46] WARNING: not removing hydrogen atom without neighbors\n",
      "[13:03:11] WARNING: not removing hydrogen atom without neighbors\n",
      "[13:03:11] WARNING: not removing hydrogen atom without neighbors\n",
      "[13:03:52] WARNING: not removing hydrogen atom without neighbors\n",
      "[13:03:52] WARNING: not removing hydrogen atom without neighbors\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train: 32901 test: 2242\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": "iVBORw0KGgoAAAANSUhEUgAAAigAAAGzCAYAAAAFROyYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA83UlEQVR4nO3df3yPdf////t+2MZ+GvZLzJLyI5FfazLEasbpR5ScqUaiTr/S3v3gLERqfp1ZROLspDpJKXSm04ohZCSssySh+VHaFNmYzI89v3/03fHpZRsbr23H5na9XI5LvY7j+TqOx/F8Ha+5v56v4zheLsYYIwAAABtxLe8CAAAALkZAAQAAtkNAAQAAtkNAAQAAtkNAAQAAtkNAAQAAtkNAAQAAtkNAAQAAtkNAAQAAtkNAwSW5uLho+PDh5V2G7axfv14uLi5av369NW/AgAGqV69eudVkBwMGDJCPj095l4E/qVevngYMGFDeZVwRFxcXPf/88+VdBsoJAeUa9fXXX+uee+5ReHi4vLy8VLt2bd15552aNWtWudW0efNmPf/88zpx4kSpbuell17SihUrSnUbxfXtt9/q+eef14EDB8q7FNuaM2eOFi5cWN5llJqyOu4rqyNHjuj5559XWlpaqW5n8eLFSkpKKtVtwBEB5Rq0efNmtWrVSl999ZUGDx6sV199VY888ohcXV31yiuvlGtdEyZMqLABZf78+dqzZ0+JnvPtt99qwoQJBJRLuBYCSmke93v27NH8+fNLZd12cOTIEU2YMIGAUgm5l3cBKHsvvvii/P39tW3bNgUEBDgsO3r0aJnXk5OTI29v7zLfrrNVqVKlvEtAJZeXl6ezZ8/Ky8ur2M/x9PQsxYqAUmRwzbnppptMx44di9VWkhk2bJhZvny5adKkifHw8DCNGzc2q1atKtB2x44dpkuXLsbX19d4e3ubTp06mdTUVIc2CxYsMJLM+vXrzd/+9jdTq1YtExAQYMaPH28kFZjS09Ot57799tumRYsWxsvLy1SvXt3cd9995tChQw7r//77703v3r1NcHCw8fT0NLVr1zb33XefOXHihLU/F0/x8fGX7IPDhw+bnj17mmrVqplatWqZUaNGmeTkZCPJrFu3zmoXHx9vwsPDHZ77zjvvmBYtWhgfHx/j6+trbr75ZpOUlOTQFxdP+etcsWKF6dq1qwkNDTUeHh7m+uuvNxMnTjTnz5932EaHDh1MkyZNzK5du0zHjh1N1apVTVhYmJkyZUqBffn999/N+PHjTYMGDYynp6cJCQkxd999t9m3b5/V5sKFC2bGjBmmcePGxtPT0wQFBZkhQ4aY48ePX7Kf8vvA29vb7N+/39x1112mWrVqJjQ01EyYMMHk5eU5tC3OdsLDwwv0T4cOHcxvv/1mXF1dzSuvvGK1/eWXX4yLi4sJDAx02NZjjz1mgoODHba9ZcsWExsba/z8/EzVqlVN+/btzaZNmwrsz48//mgGDhxogoKCrGP/jTfecGizbt06I8m8++67ZtKkSaZ27drG09PTdOrUyezdu/eS/XW54z7//ffvf//bNG7c2Li7u5vly5cbY4yZNm2aiYqKMoGBgcbLy8u0aNHCLF26tMA2wsPDHY7x/ONu06ZN5oknnjA1a9Y01apVM7169TJHjx69ZL3GGPPVV1+Z+Ph4ExERYTw9PU1wcLAZOHCg+fXXXwvdt71795r4+Hjj7+9v/Pz8zIABA0xOTo5D2zNnzphRo0aZmjVrGh8fH9O9e3dz+PBhI8mMHz++yFry+/7iacGCBVab4rzW2dnZ5vHHHzfh4eHGw8PD1KpVy8TExJjt27cbY/54j128jYvf63A+RlCuQeHh4UpNTdU333yjm2+++bLtN23apGXLlmno0KHy9fXVzJkz1adPHx06dEg1atSQJO3atUvR0dHy8/PT008/rSpVquj1119Xx44d9dlnnykyMtJhnUOHDlWtWrU0btw45eTkKC4uTt9//73eeecdzZgxQzVr1pQk1apVS9Ifoz5jx45V37599cgjj+iXX37RrFmz1L59e+3cuVMBAQE6e/asYmNjlZubqxEjRigkJEQ//fSTVq5cqRMnTsjf319vv/22HnnkEbVp00ZDhgyRJNWvX7/Iff/999/VuXNnHTp0SCNHjlRYWJjefvttrV279rL9tnr1av31r39V586dNWXKFEnS7t279fnnn+vxxx9X+/btNXLkSM2cOVN///vf1ahRI0my/rtw4UL5+PgoISFBPj4+Wrt2rcaNG6fs7GxNmzbNYVu//fabunTpot69e6tv3756//339cwzz6hp06aKi4uTJF24cEF/+ctflJKSon79+unxxx/XyZMntXr1an3zzTdWPzz66KNauHChBg4cqJEjRyo9PV2vvvqqdu7cqc8///yyI0UXLlxQly5ddNttt2nq1KlKTk7W+PHjdf78eU2cONFqV5ztJCUlacSIEfLx8dGzzz4rSQoODlZAQIBuvvlmbdiwQSNHjpT0x3Hq4uKi48eP69tvv1WTJk0kSRs3blR0dLS13bVr1youLk4tW7bU+PHj5erqqgULFqhTp07auHGj2rRpI0nKzMzUbbfdZp0oXqtWLa1atUqDBg1Sdna2Ro0a5bDfkydPlqurq5588kllZWVp6tSp6t+/v7Zu3VpkX/Xu3fuSx31+ve+9956GDx+umjVrWidiv/LKK+rRo4f69++vs2fPasmSJbr33nu1cuVKdevW7ZKvkSSNGDFC1atX1/jx43XgwAElJSVp+PDhevfddy/5vNWrV+uHH37QwIEDFRISol27dmnevHnatWuXtmzZIhcXF4f2ffv2VUREhBITE7Vjxw7985//VFBQkPWekKRHHnlE//73v3X//ferbdu2Wrt2bbH2oVGjRpo4caLGjRunIUOGWK9z27Ztrb4rzmv92GOP6f3339fw4cPVuHFjHTt2TJs2bdLu3bvVokULPfvss8rKytKPP/6oGTNmSBIng5eF8k5IKHuffvqpcXNzM25ubiYqKso8/fTT5pNPPjFnz54t0FaS8fDwcPiE/dVXXxlJZtasWda8Xr16GQ8PD7N//35r3pEjR4yvr69p3769NS//01u7du0KjARMmzatwKiJMcYcOHDAuLm5mRdffNFh/tdff23c3d2t+Tt37jSSCv0U+Wfe3t6XHTXJl5SUZCSZ9957z5qXk5NjbrjhhsuOoDz++OPGz8+vwH7+2dKlSwusJ9/p06cLzHv00UdNtWrVzJkzZ6x5+Z/u3nrrLWtebm6uCQkJMX369LHm/etf/zKSzMsvv1xgvfkjDhs3bjSSzKJFixyW548YXTz/YvHx8UaSGTFihMO6u3XrZjw8PMwvv/xS4u00adLEdOjQocC2hg0b5jAykpCQYNq3b2+CgoLMa6+9Zowx5tixY8bFxcUaacnLyzMNGjQwsbGxDqMsp0+fNhEREebOO++05g0aNMiEhoYWGBno16+f8ff3t16f/E/xjRo1Mrm5uVa7V155xUgyX3/99SX7rKjj3pg/3n+urq5m165dBZZdfHycPXvW3HzzzaZTp04O84saQYmJiXHogyeeeMK4ublZo41FKey4fOedd4wks2HDBmte/gjKww8/7ND27rvvNjVq1LAep6WlGUlm6NChDu3uv//+y46gGGPMtm3bCoyaGFOy19rf398MGzbsktvp1q0boyZljJNkr0F33nmnUlNT1aNHD3311VeaOnWqYmNjVbt2bf3nP/8p0D4mJsZhlOGWW26Rn5+ffvjhB0l/fGL+9NNP1atXL11//fVWu9DQUN1///3atGmTsrOzHdY5ePBgubm5FaveZcuWKS8vT3379tWvv/5qTSEhIWrQoIHWrVsnSfL395ckffLJJzp9+nTJOqUI//3vfxUaGqp77rnHmletWjVr9OVSAgIClJOTo9WrV1/RtqtWrWr9/8mTJ/Xrr78qOjpap0+f1nfffefQ1sfHRw888ID12MPDQ23atLFeI0n64IMPVLNmTY0YMaLAtvI/9S5dulT+/v668847Hfq6ZcuW8vHxsfr6cv58aXr+CMTZs2e1Zs0ap20nOjpamZmZ1onJGzduVPv27RUdHa2NGzdK+mNUxRhjfbJOS0vT3r17df/99+vYsWPWdnNyctS5c2dt2LBBeXl5Msbogw8+UPfu3WWMcagxNjZWWVlZ2rFjh0M9AwcOlIeHh0N9khxegyvRoUMHNW7cuMD8Px8fv/32m7KyshQdHV2grqIMGTLEYbQjOjpaFy5c0MGDBy/5vD9v98yZM/r111912223SVKh237sscccHkdHR+vYsWPW34T//ve/kmSNhOW7eISqpIr7Wkt/vFe3bt2qI0eOXNU24Vx8xXONat26tZYtW6azZ8/qq6++0vLlyzVjxgzdc889SktLc/iDWLdu3QLPr169un777TdJ0i+//KLTp0/rpptuKtCuUaNGysvL0+HDh60hd0mKiIgodq179+6VMUYNGjQodHn+Vw4RERFKSEjQyy+/rEWLFik6Olo9evTQAw88YIWXkjp48KBuuOGGAsPWhe3rxYYOHar33ntPcXFxql27tu666y717dtXXbp0Kda2d+3apeeee05r164tEPCysrIcHl933XUFaqxevbr+97//WY/379+vm266Se7uRb/t9+7dq6ysLAUFBRW6vDgnUbu6ujoEVUm68cYbJcm6WskZ28kPABs3btR1112nnTt3atKkSapVq5amT59uLfPz81OzZs2s7UpSfHx8kevNysrSuXPndOLECc2bN0/z5s0rVo0Xv0+qV68uSdb75EoV9V5ZuXKlJk2apLS0NOXm5lrzLz4OinKl9R4/flwTJkzQkiVLCvTBxcfl5bbj5+engwcPytXVtcBXrcV5j11KcV/r6tWra+rUqYqPj1edOnXUsmVLde3aVQ899FCB4xhli4ByjfPw8FDr1q3VunVr3XjjjRo4cKCWLl2q8ePHW22KGukwxlzxdv/8Kexy8vLy5OLiolWrVhVay5+/C/7HP/6hAQMG6MMPP9Snn36qkSNHKjExUVu2bNF11113xfVeiaCgIKWlpemTTz7RqlWrtGrVKi1YsEAPPfSQ3nzzzUs+98SJE+rQoYP8/Pw0ceJE1a9fX15eXtqxY4eeeeYZ65NfPme9Rnl5eQoKCtKiRYsKXf7ncyOuhjO2ExYWpoiICG3YsEH16tWTMUZRUVGqVauWHn/8cR08eFAbN25U27Zt5erqam1XkqZNm6bmzZsXul4fHx8dO3ZMkvTAAw8U+Q/cLbfc4vC4NN4nUuHvlY0bN6pHjx5q37695syZo9DQUFWpUkULFizQ4sWLi7XeK623b9++2rx5s5566ik1b95cPj4+ysvLU5cuXQocl1eznatV3Nda+mOfoqOjtXz5cn366aeaNm2apkyZomXLllnncKHsEVBgadWqlSTp559/LtHzatWqpWrVqhV6D5DvvvtOrq6uqlOnzmXXU9Qnv/r168sYo4iICOuT+KU0bdpUTZs21XPPPafNmzfr9ttv19y5czVp0qRLbqcw4eHh+uabb2SMcXhece934uHhoe7du6t79+7Ky8vT0KFD9frrr2vs2LGFjszkW79+vY4dO6Zly5apffv21vz09PRi136x+vXra+vWrTp37lyRJ7rWr19fa9as0e23316iEPlneXl5+uGHHxxeq++//16SrBM8S7KdS71e0dHR2rBhgyIiItS8eXP5+vqqWbNm8vf3V3Jysnbs2KEJEyY47J8k+fn5KSYmpsj11qpVS76+vrpw4cIl2zlDSY7HfB988IG8vLz0ySefOFxGvGDBAmeWVsBvv/2mlJQUTZgwQePGjbPm549WXInw8HDl5eVZI3z5ivseu9TfDenyr3W+0NBQDR06VEOHDtXRo0fVokULvfjii1ZAuZLXCVeHc1CuQevWrSv000v+d8ElHVp1c3PTXXfdpQ8//NDhhmOZmZlavHix2rVrJz8/v8uuJ/9eKBffsKp3795yc3PThAkTCtRtjLE+7WZnZ+v8+fMOy5s2bSpXV1eHIXBvb+9i3xSra9euOnLkiN5//31r3unTp4sc9v+z/Lryubq6Wp+68+spap/zP3X+eX/Pnj2rOXPmFKvuwvTp00e//vqrXn311QLL8rfTt29fXbhwQS+88EKBNufPny92v/15G8YYvfrqq6pSpYo6d+5c4u1c6vWKjo7WgQMH9O6771pf+bi6uqpt27Z6+eWXde7cOYcreFq2bKn69etr+vTpOnXqVIH1/fLLL5L+6P8+ffrogw8+0DfffFNkO2co6hi4FDc3N7m4uOjChQvWvAMHDpT6HZILOy4lXdUNzPIDwMyZM69onUX1X3Ff6wsXLhT4aiooKEhhYWEF/m4U9hUWSg8jKNegESNG6PTp07r77rvVsGFDnT17Vps3b9a7776revXqaeDAgSVe56RJk7R69Wq1a9dOQ4cOlbu7u15//XXl5uZq6tSpxVpHy5YtJUnPPvus+vXrpypVqqh79+6qX7++Jk2apDFjxujAgQPq1auXfH19lZ6eruXLl2vIkCF68skntXbtWg0fPlz33nuvbrzxRp0/f15vv/229Y/Nn7ezZs0avfzyy9bXBBdfBp0v/067Dz30kLZv367Q0FC9/fbbqlat2mX355FHHtHx48fVqVMnXXfddTp48KBmzZql5s2bW5cSN2/eXG5ubpoyZYqysrLk6empTp06qW3btqpevbri4+M1cuRIubi46O23376qYfGHHnpIb731lhISEvTFF18oOjpaOTk5WrNmjYYOHaqePXuqQ4cOevTRR5WYmKi0tDTdddddqlKlivbu3aulS5fqlVdecThhuDBeXl5KTk5WfHy8IiMjtWrVKn388cf6+9//bn11U5LttGzZUq+99pomTZqkG264QUFBQerUqZOk/3ceyp49e/TSSy9ZNbRv316rVq2Sp6enWrdubc13dXXVP//5T8XFxalJkyYaOHCgateurZ9++knr1q2Tn5+fPvroI0l/XDa8bt06RUZGavDgwWrcuLGOHz+uHTt2aM2aNTp+/PgVvxZ/VtRxf6mbF3br1k0vv/yyunTpovvvv19Hjx7V7NmzdcMNNzicd+Rsfn5+at++vaZOnapz586pdu3a+vTTT69qZK958+b661//qjlz5igrK0tt27ZVSkqK9u3bV6zn169fXwEBAZo7d658fX3l7e2tyMhIRUREFOu1PnnypK677jrdc889atasmXx8fLRmzRpt27ZN//jHP6zttGzZUu+++64SEhLUunVr+fj4qHv37le83yiGsr1oCHawatUq8/DDD5uGDRsaHx8f4+HhYW644QYzYsQIk5mZ6dBW//+Noi528aWLxvxxo7bY2Fjj4+NjqlWrZu644w6zefNmhzb5lzhu27at0NpeeOEFU7t2bePq6lrg0ssPPvjAtGvXznh7extvb2/TsGFDM2zYMLNnzx5jjDE//PCDefjhh039+vWNl5eXCQwMNHfccYdZs2aNwza+++470759e1O1atVi3ajt4MGDpkePHqZatWqmZs2a5vHHHy/Wjdref/99c9ddd1k3+apbt6559NFHzc8//+yw/vnz55vrr7/euLm5Oazz888/N7fddpt147X8y8Ev3m7+jdouVtiN406fPm2effZZExERYapUqWJCQkLMPffc43B5uDHGzJs3z7Rs2dJUrVrV+Pr6mqZNm5qnn37aHDly5JJ9VdiN2oKDg8348ePNhQsXCrQvznYyMjJMt27djK+vr3Wjtj8LCgoykhyO3U2bNhlJJjo6utA6d+7caXr37m1q1KhhPD09TXh4uOnbt69JSUlxaJeZmWmGDRtm6tSpY/VX586dzbx586w2+ZcZX3x5e3p6eqGXvxamqOO+qPefMca88cYb1g33GjZsaBYsWGBd2vtnRV1mfPF7MH8/Crvk/c9+/PFHc/fdd5uAgADj7+9v7r33XnPkyJEClwTn15J/afnF2//ze/v33383I0eONDVq1DDe3t7FvlFbvg8//NC6kd3FfX651zo3N9c89dRTplmzZtZNJps1a2bmzJnjsI1Tp06Z+++/3wQEBHCjtjLiYkwpn6kEAABQQpyDAgAAbIeAAgAAbIeAAgAAbIeAAgAAbIeAAgAAbIeAAgAAbKdC3qgtLy9PR44cka+vL7cfBgCggjDG6OTJkwoLC7N+I6soFTKgHDlypFi/7QIAAOzn8OHDl/0B1woZUHx9fSX9sYPF+Y0XAABQ/rKzs1WnTh3r3/FLqZABJf9rHT8/PwIKAAAVTHFOz+AkWQAAYDsEFAAAYDsEFAAAYDsEFAAAYDsEFAAAYDsEFAAAYDsEFAAAYDsEFAAAYDsEFAAAYDsEFAAA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ALAdAgoAALAdAgoAALAdAgoAALAdAgoAALAdAgoAALAdAgoAALAdAgoAALAdAgoAALAdAgoAALAdAgoAALAdAgoAALAdAgoAALAdAgoAALAd95I+YcOGDZo2bZq2b9+un3/+WcuXL1evXr0kSefOndNzzz2n//73v/rhhx/k7++vmJgYTZ48WWFhYdY6jh8/rhEjRuijjz6Sq6ur+vTpo1deeUU+Pj5O2zEAwNWrN/rjy7Y5MLlbGVRSPq71/S9PJR5BycnJUbNmzTR79uwCy06fPq0dO3Zo7Nix2rFjh5YtW6Y9e/aoR48eDu369++vXbt2afXq1Vq5cqU2bNigIUOGXPleAACASqXEIyhxcXGKi4srdJm/v79Wr17tMO/VV19VmzZtdOjQIdWtW1e7d+9WcnKytm3bplatWkmSZs2apa5du2r69OkOIy0AANhdcUZZUHKlfg5KVlaWXFxcFBAQIElKTU1VQECAFU4kKSYmRq6urtq6dWuh68jNzVV2drbDBAAAKq9SDShnzpzRM888o7/+9a/y8/OTJGVkZCgoKMihnbu7uwIDA5WRkVHoehITE+Xv729NderUKc2yAQBAOSu1gHLu3Dn17dtXxhi99tprV7WuMWPGKCsry5oOHz7spCoBAIAdlfgclOLIDycHDx7U2rVrrdETSQoJCdHRo0cd2p8/f17Hjx9XSEhIoevz9PSUp6dnaZQKAABsyOkjKPnhZO/evVqzZo1q1KjhsDwqKkonTpzQ9u3brXlr165VXl6eIiMjnV0OAACogEo8gnLq1Cnt27fPepyenq60tDQFBgYqNDRU99xzj3bs2KGVK1fqwoUL1nklgYGB8vDwUKNGjdSlSxcNHjxYc+fO1blz5zR8+HD169ePK3gAAICkKwgoX375pe644w7rcUJCgiQpPj5ezz//vP7zn/9Ikpo3b+7wvHXr1qljx46SpEWLFmn48OHq3LmzdaO2mTNnXuEuAACAyqbEAaVjx44yxhS5/FLL8gUGBmrx4sUl3TQAALhG8Fs8AADAdggoAADAdggoAADAdggoAADAdggoAADAdggoAADAdkrlVvcAAJSneqM/vmybA5O7lUEluFKMoAAAANthBAUAUOoY0UBJMYICAABsh4ACAABsh4ACAABsh4ACAABsh4ACAABsh4ACAABsh4ACAABsh4ACAABsh4AC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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "train_2, test_2, sim_2 = get_hi_split(hiv, 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": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[13:04:08] WARNING: not removing hydrogen atom without neighbors\n",
      "[13:04:08] WARNING: not removing hydrogen atom without neighbors\n",
      "[13:07:11] WARNING: not removing hydrogen atom without neighbors\n",
      "[13:07:11] WARNING: not removing hydrogen atom without neighbors\n",
      "[13:07:49] WARNING: not removing hydrogen atom without neighbors\n",
      "[13:07:49] WARNING: not removing hydrogen atom without neighbors\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train: 32901 valid: 2285\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Shortest distance between train and test')"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAigAAAGzCAYAAAAFROyYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA3/klEQVR4nO3de1xVVeL38e8B5aByE+VqiIillre8kY7gjRT0p5mWY9qEZlrjreTplzGViuMMpo1ZpjU1pZOjaZbZjI2W19QRHdPIsnLUUHMUTE1QTFRYzx89nMcjoEDnyAY/79drv/TsvfZea591NnxZ+3JsxhgjAAAAC/Go7AYAAABcjYACAAAsh4ACAAAsh4ACAAAsh4ACAAAsh4ACAAAsh4ACAAAsh4ACAAAsh4ACAAAsh4CCa7LZbBo3blxlN8NyNm3aJJvNpk2bNjnmDR8+XI0aNaq0NlnB8OHD5ePjU9nNwBUaNWqk4cOHV3YzKsRms2nq1KmV3QxUEgLKTerLL7/Ufffdp8jISHl7e6tBgwa6++67NXfu3Epr07Zt2zR16lSdOXPGrfX88Y9/1MqVK91aR1l9/fXXmjp1qg4dOlTZTbGs+fPna+HChZXdDLe5UZ/76urYsWOaOnWqMjIy3FrPkiVLNGfOHLfWAWcElJvQtm3b1L59e33xxRcaNWqUXnnlFT3yyCPy8PDQSy+9VKntSk1NrbIB5Y033tC+ffvKtc7XX3+t1NRUAso13AwBxZ2f+3379umNN95wy7at4NixY0pNTSWgVEM1KrsBuPH+8Ic/yN/fXzt37lRAQIDTshMnTtzw9uTl5alOnTo3vF5Xq1mzZmU3AdVcYWGhLl68KG9v7zKvY7fb3dgiwI0MbjpNmzY13bp1K1NZSWbs2LHmgw8+MHfccYfx8vIyt99+u1m9enWxsrt37zYJCQnG19fX1KlTx/To0cOkp6c7lVmwYIGRZDZt2mR++9vfmqCgIBMQEGCmTJliJBWbMjMzHesuWrTItG3b1nh7e5u6deuaX//61+bIkSNO2//Pf/5jBg4caEJCQozdbjcNGjQwv/71r82ZM2cc+3P1lJSUdM334Pvvvzf33HOPqV27tgkKCjJPPPGEWbNmjZFkNm7c6CiXlJRkIiMjndZ95513TNu2bY2Pj4/x9fU1LVq0MHPmzHF6L66eira5cuVK06dPHxMWFma8vLxM48aNzbRp08zly5ed6ujatau54447zN69e023bt1MrVq1THh4uHn++eeL7ctPP/1kpkyZYm699VZjt9tNaGiouffee82BAwccZQoKCsyLL75obr/9dmO3201wcLAZPXq0OX369DXfp6L3oE6dOubgwYOmV69epnbt2iYsLMykpqaawsJCp7JlqScyMrLY+9O1a1fz448/Gg8PD/PSSy85yv7www/GZrOZwMBAp7oee+wxExIS4lT39u3bTe/evY2fn5+pVauWiYuLM1u3bi22P0ePHjUjRowwwcHBjs/+m2++6VRm48aNRpJZtmyZmT59umnQoIGx2+2mR48eZv/+/dd8v673uS86/v72t7+Z22+/3dSoUcN88MEHxhhjZs2aZTp16mQCAwONt7e3adu2rVm+fHmxOiIjI50+40Wfu61bt5qJEyea+vXrm9q1a5sBAwaYEydOXLO9xhjzxRdfmKSkJBMVFWXsdrsJCQkxI0aMMCdPnixx3/bv32+SkpKMv7+/8fPzM8OHDzd5eXlOZS9cuGCeeOIJU79+fePj42P69etnvv/+eyPJTJkypdS2FL33V08LFixwlClLX+fm5prHH3/cREZGGi8vLxMUFGTi4+PNrl27jDE/H2NX13H1sQ7XYwTlJhQZGan09HR99dVXatGixXXLb926VStWrNCYMWPk6+url19+WYMGDdKRI0dUr149SdLevXsVGxsrPz8/PfXUU6pZs6b+/Oc/q1u3bvr0008VExPjtM0xY8YoKChIkydPVl5enhITE/Wf//xH77zzjl588UXVr19fkhQUFCTp51Gf5557ToMHD9YjjzyiH374QXPnzlVcXJw+//xzBQQE6OLFi+rdu7fy8/M1fvx4hYaG6r///a9WrVqlM2fOyN/fX4sWLdIjjzyijh07avTo0ZKk6OjoUvf9p59+Us+ePXXkyBFNmDBB4eHhWrRokTZs2HDd923t2rV64IEH1LNnTz3//POSpG+++Ub/+te/9PjjjysuLk4TJkzQyy+/rN/97ndq3ry5JDn+XbhwoXx8fJScnCwfHx9t2LBBkydPVm5urmbNmuVU148//qiEhAQNHDhQgwcP1nvvvadJkyapZcuWSkxMlCQVFBTof/7nf7R+/XoNGTJEjz/+uM6ePau1a9fqq6++crwPjz76qBYuXKgRI0ZowoQJyszM1CuvvKLPP/9c//rXv647UlRQUKCEhATdddddmjlzptasWaMpU6bo8uXLmjZtmqNcWeqZM2eOxo8fLx8fHz3zzDOSpJCQEAUEBKhFixbavHmzJkyYIOnnz6nNZtPp06f19ddf64477pAkbdmyRbGxsY56N2zYoMTERLVr105TpkyRh4eHFixYoB49emjLli3q2LGjJCk7O1t33XWX40LxoKAgrV69WiNHjlRubq6eeOIJp/2eMWOGPDw89OSTTyonJ0czZ87UsGHDtGPHjlLfq4EDB17zc1/U3nfffVfjxo1T/fr1HRdiv/TSS+rfv7+GDRumixcvaunSpbr//vu1atUq9e3b95p9JEnjx49X3bp1NWXKFB06dEhz5szRuHHjtGzZsmuut3btWn333XcaMWKEQkNDtXfvXr3++uvau3evtm/fLpvN5lR+8ODBioqKUlpamnbv3q2//OUvCg4OdhwTkvTII4/ob3/7m4YOHarOnTtrw4YNZdqH5s2ba9q0aZo8ebJGjx7t6OfOnTs73ruy9PVjjz2m9957T+PGjdPtt9+uU6dOaevWrfrmm2/Utm1bPfPMM8rJydHRo0f14osvShIXg98IlZ2QcON98sknxtPT03h6eppOnTqZp556ynz88cfm4sWLxcpKMl5eXk5/YX/xxRdGkpk7d65j3oABA4yXl5c5ePCgY96xY8eMr6+viYuLc8wr+uutS5cuxUYCZs2aVWzUxBhjDh06ZDw9Pc0f/vAHp/lffvmlqVGjhmP+559/biSV+FfklerUqXPdUZMic+bMMZLMu+++65iXl5dnmjRpct0RlMcff9z4+fkV288rLV++vNh2ipw/f77YvEcffdTUrl3bXLhwwTGv6K+7t99+2zEvPz/fhIaGmkGDBjnmvfXWW0aSmT17drHtFo04bNmyxUgyixcvdlpeNGJ09fyrJSUlGUlm/PjxTtvu27ev8fLyMj/88EO567njjjtM165di9U1duxYp5GR5ORkExcXZ4KDg82rr75qjDHm1KlTxmazOUZaCgsLza233mp69+7tNMpy/vx5ExUVZe6++27HvJEjR5qwsLBiIwNDhgwx/v7+jv4p+iu+efPmJj8/31HupZdeMpLMl19+ec33rLTPvTE/H38eHh5m7969xZZd/fm4ePGiadGihenRo4fT/NJGUOLj453eg4kT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0kV+fn7X3U7Rs1CufmDVwIED5enpqdTU1GLtNsY4/trNzc3V5cuXnZa3bNlSHh4eTkPgderUKfNDsfr06aNjx47pvffec8w7f/58qcP+VypqVxEPDw/HX91F7Sltn4v+6rxyfy9evKj58+eXqd0lGTRokE6ePKlXXnml2LKiegYPHqyCggL9/ve/L1bm8uXLZX7frqzDGKNXXnlFNWvWVM+ePctdz7X6KzY2VocOHdKyZcscp3w8PDzUuXNnzZ49W5cuXXK6g6ddu3aKjo7WCy+8oHPnzhXb3g8//CDp5/d/0KBBev/99/XVV1+VWs4VSvsMXIunp6dsNpsKCgoc8w4dOuT2JySX9LmU9IseYFYUAF5++eUKbbO096+sfV1QUFDs1FRwcLDCw8OL/dwo6RQW3IcRlJvQ+PHjdf78ed17771q1qyZLl68qG3btmnZsmVq1KiRRowYUe5tTp8+XWvXrlWXLl00ZswY1ahRQ3/+85+Vn5+vmTNnlmkb7dq1kyQ988wzGjJkiGrWrKl+/fopOjpa06dPV0pKig4dOqQBAwbI19dXmZmZ+uCDDzR69Gg9+eST2rBhg8aNG6f7779ft912my5fvqxFixY5ftlcWc+6des0e/Zsx2mCq2+DLlL0pN2HHnpIu3btUlhYmBYtWqTatWtfd38eeeQRnT59Wj169NAtt9yiw4cPa+7cuWrTpo3jVuI2bdrI09NTzz//vHJycmS329WjRw917txZdevWVVJSkiZMmCCbzaZFixb9omHxhx56SG+//baSk5P173//W7GxscrLy9O6des0ZswY3XPPPerataseffRRpaWlKSMjQ7169VLNmjW1f/9+LV++XC+99JLTBcMl8fb21po1a5SUlKSYmBitXr1aH330kX73u985Tt2Up5527drp1Vdf1fTp09WkSRMFBwerR48ekv7/dSj79u3TH//4R0cb4uLitHr1atntdnXo0MEx38PDQ3/5y1+UmJioO+64QyNGjFCDBg303//+Vxs3bpSfn5/+8Y9/SPr5tuGNGzcqJiZGo0aN0u23367Tp09r9+7dWrdunU6fPl3hvrhSaZ/7az28sG/fvpo9e7YSEhI0dOhQnThxQvPmzVOTJk2crjtyNT8/P8XFxWnmzJm6dOmSGjRooE8++eQXjey1adNGDzzwgObPn6+cnBx17txZ69ev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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(hiv, 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": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib_venn._common.VennDiagram at 0x7f54e04a4cd0>"
      ]
     },
     "execution_count": 8,
     "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": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_1.to_csv('../../data/hi/hiv_greedy/train_1.csv')\n",
    "train_2.to_csv('../../data/hi/hiv_greedy/train_2.csv')\n",
    "train_3.to_csv('../../data/hi/hiv_greedy/train_3.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_1.to_csv('../../data/hi/hiv_greedy/test_1.csv')\n",
    "test_2.to_csv('../../data/hi/hiv_greedy/test_2.csv')\n",
    "test_3.to_csv('../../data/hi/hiv_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
}
