{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Skipped loading some Tensorflow models, missing a dependency. No module named 'tensorflow'\n",
      "Skipped loading modules with pytorch-lightning dependency, missing a dependency. No module named 'pytorch_lightning'\n",
      "Skipped loading some Jax models, missing a dependency. No module named 'jax'\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from rdkit import Chem\n",
    "import deepchem as dc\n",
    "from deepchem.molnet.load_function.hiv_datasets import load_hiv\n",
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../../code')\n",
    "\n",
    "from splits import get_nearest_mols"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# GOOD-HIV, Scaffold, Covariate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "data, _ = torch.load('../../data/raw/GOODHIV/scaffold/processed/covariate_train.pt')\n",
    "train_smiles = data.smiles\n",
    "data, _ = torch.load('../../data/raw/GOODHIV/scaffold/processed/covariate_test.pt')\n",
    "test_smiles = data.smiles"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "nearest_dist, nearest_idx = get_nearest_mols(test_smiles, train_smiles, return_idx=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'The nearest distance between train and test')"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiwAAAGzCAYAAAAMr0ziAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA5d0lEQVR4nO3dd3hUZf7//1cKKYQUAqRBCBDUgICwQTBAACUaICAu7CLKInApWAL7gdhAlCYaUVSUpexaYHVlVRRQihTpakBFWCmKVBEwVEkoEkhy//7wl/kyJJBM6g15Pq5rros5c8+53/c5M5kX9zlnxs0YYwQAAGAx94ouAAAAoDAEFgAAYD0CCwAAsB6BBQAAWI/AAgAArEdgAQAA1iOwAAAA6xFYAACA9QgsAADAegSWa9zq1avl5uamjz76qKJLgaR9+/bJzc1Ns2bNciwbO3as3NzcKq4oC+Rtg2PHjlV0Kfj/dezYUR07dqzoMoqlXr16GjBgQEWXgVJGYLkKubm5Fem2evXqii71mjJt2jSnoFGRDh06pLFjx2rz5s0VXYq1Zs+ercmTJ1d0GWVm+/btGjt2rPbt21fRpVyVzp49q7Fjx5b538nFixdr7NixZdpHZeFZ0QXAde+++67T/XfeeUfLly/Pt7xRo0b64YcfyrO0a9q0adNUs2bNUv+f29NPP60RI0a49JxDhw5p3Lhxqlevnpo3b16q9VwrZs+era1bt2rYsGEVXUqZ2L59u8aNG6eOHTuqXr16pb7+ZcuWlfo6bXL27FmNGzdOksp0Jmnx4sWaOnUqoaUUEFiuQn/729+c7q9fv17Lly/Pt1xSpQ0sZ86ckZ+fX0WXUSSenp7y9OStiLJjjNG5c+fk6+tb5Od4eXmVYUWA6zgkVEnk5ubqueeeU506deTj46NOnTpp165d+dpt2LBBnTt3VmBgoKpWraoOHTroyy+/LHT9eefKfPjhh6XWz88//6xHHnlEN9xwg3x9fVWjRg399a9/zTcFPmvWLLm5uWnNmjV65JFHFBISojp16jge/+yzzxQfHy8/Pz/5+/srKSlJ27Ztc1pHenq6Bg4cqDp16sjb21vh4eHq0aOHo6969epp27ZtWrNmjeOQW2H/Kzt58qQGDBigwMBABQUFqX///jp58mS+dgWdw7J8+XK1a9dOQUFBqlatmm644QY99dRTjm198803S5IGDhzoqCfvcNW6dev017/+VXXr1pW3t7ciIyM1fPhw/f777059DBgwQNWqVdPBgwd11113qVq1aqpVq5Yee+wx5eTkOLXNzc3Va6+9pqZNm8rHx0e1atVS586d9e233zq1+89//qPY2Fj5+voqODhYffr00S+//HLF7XSxY8eOqXfv3goICFCNGjX0f//3fzp37ly+doX107FjRy1atEg///yzY/vUq1dPxhjVrFlTKSkpTmMLCgqSh4eH0/6ZOHGiPD09dfr0aceyH3/8UX/5y18UHBwsHx8ftWzZUp9++mm++k6ePKlhw4YpMjJS3t7eatiwoSZOnKjc3FxHm7zzmSZNmqR//etfio6Olre3t26++WZ98803V9xOs2bN0l//+ldJ0q233prvMHC9evXUrVs3LV26VC1btpSvr6/++c9/SpJmzpyp2267TSEhIfL29lbjxo01ffr0fH1ceg6Lq+/xS7n6fv7yyy+VkpKiWrVqyc/PT3/+85919OhRp7bGGE2YMEF16tRR1apVdeutt+Z7bxdk3759qlWrliRp3Lhxju138SxIUfb1hQsXNG7cOF133XXy8fFRjRo11K5dOy1fvlzSH++xqVOnSnI+lI/i4b91lcQLL7wgd3d3PfbYY8rIyNCLL76ovn37asOGDY42K1euVJcuXRQbG6sxY8bI3d3d8cdt3bp1atWqVbn288033+irr75Snz59VKdOHe3bt0/Tp09Xx44dtX37dlWtWtWp70ceeUS1atXS6NGjdebMGUl/HD7r37+/EhMTNXHiRJ09e1bTp09Xu3bttGnTJsdUeq9evbRt2zYNHTpU9erV05EjR7R8+XLt379f9erV0+TJkzV06FBVq1ZNo0aNkiSFhoZedjsYY9SjRw998cUXeuihh9SoUSPNmzdP/fv3L3Qbbtu2Td26dVOzZs00fvx4eXt7a9euXY5A16hRI40fP16jR4/W4MGDFR8fL0lq06aNJGnOnDk6e/asHn74YdWoUUNff/21pkyZogMHDmjOnDlOfeXk5CgxMVGtW7fWpEmT9Pnnn+vll19WdHS0Hn74YUe7+++/X7NmzVKXLl30wAMPKDs7W+vWrdP69evVsmVLSdJzzz2nZ555Rr1799YDDzygo0ePasqUKWrfvr02bdqkoKCgQsfeu3dv1atXT6mpqVq/fr1ef/11/fbbb3rnnXccbYrSz6hRo5SRkaEDBw7o1VdflSRVq1ZNbm5uatu2rdauXetY3/fff6+MjAy5u7vryy+/VFJSkqQ/gl+LFi1UrVo1x35p27atateurREjRsjPz08ffvih7rrrLn388cf685//LOmPQw0dOnTQwYMH9eCDD6pu3br66quvNHLkSP3666/5zquZPXu2Tp06pQcffFBubm568cUX1bNnT+3Zs0dVqlQpcDu1b99ef//73/X666/rqaeeUqNGjRyvjTw7duzQPffcowcffFCDBg3SDTfcIEmaPn26brzxRt15553y9PTUggUL9Mgjjyg3N1fJycmF7qOivMcL4ur7eejQoapevbrGjBmjffv2afLkyRoyZIg++OADR5vRo0drwoQJ6tq1q7p27arvvvtOd9xxh86fP3/FWmrVqqXp06fr4Ycf1p///Gf17NlTktSsWTNJRd/XY8eOVWpqqh544AG1atVKmZmZ+vbbb/Xdd9/p9ttv14MPPqhDhw4VeMgexWBw1UtOTjaX25WrVq0ykkyjRo1MVlaWY/lrr71mJJktW7YYY4zJzc011113nUlMTDS5ubmOdmfPnjX169c3t99++xVrKIt+zp49m6+ftLQ0I8m88847jmUzZ840kky7du1Mdna2Y/mpU6dMUFCQGTRokNM60tPTTWBgoGP5b7/9ZiSZl1566YpjvPHGG02HDh2u2CbP/PnzjSTz4osvOpZlZ2eb+Ph4I8nMnDnTsXzMmDFO++/VV181kszRo0cvu/5vvvkm33ryFLTdUlNTjZubm/n5558dy/r3728kmfHjxzu1bdGihYmNjXXcX7lypZFk/v73v+dbb94+3Ldvn/Hw8DDPPfec0+Nbtmwxnp6e+ZZfKm8b3HnnnU7LH3nkESPJ/O9//3O5n6SkJBMVFZWvr5deesl4eHiYzMxMY4wxr7/+uomKijKtWrUyTz75pDHGmJycHBMUFGSGDx/ueF6nTp1M06ZNzblz55zG36ZNG3Pdddc5lj377LPGz8/P/PTTT079jhgxwnh4eJj9+/cbY4zZu3evkWRq1KhhTpw44Wj3ySefGElmwYIFV9xmc+bMMZLMqlWr8j0WFRVlJJklS5bke6yg10diYqJp0KCB07IOHTo4vd6L+h6/HFffzwkJCU5/I4YPH248PDzMyZMnjTHGHDlyxHh5eZmk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jnHVqlVm7ty5Zvv27WbXrl1m8uTJxsPDwyxZsqScKy86V8eYZ+/evaZ27domPj7e9OjRo3yKLSZXxzhz5kwTEBBgfv31V8ctPT29nKt2jatjzMrKMi1btjRdu3Y1X3zxhdm7d69ZvXq12bx5czlX7hpXx3n8+HGn/bh161bj4eFhZs6cWb6Fu8DVMb733nvG29vbvPfee2bv3r1m6dKlJjw83AwfPrycKy86V8f4xBNPmIiICLNo0SKze/duM23aNOPj42O+++67cq686BYvXmxGjRpl5s6daySZefPmXbH9nj17TNWqVU1KSorZvn27mTJlSrE+PwgsBWjVqpVJTk523M/JyTEREREmNTW1SM/Pzs42/v7+5t///ndZlVhiJR2jMca0aNHCPP3002VRXqkozhizs7NNmzZtzJtvvmn69+9vfWBxdYwzZ840gYGB5VRd6XB1jNOnTzcNGjQw58+fL68SS0VJ35Ovvvqq8ff3N6dPny6rEkvM1TEmJyeb2267zWlZSkqKadu2bZnWWRKujjE8PNz84x//cFrWs2dP07dv3zKts7QUJbA88cQT5sYbb3Radvfdd5vExESX+uKQ0CXOnz+vjRs3KiEhwbHM3d1dCQkJSktLK9I6zp49qwsXLig4OLisyiyRko7RGKMVK1Zox44dat++fVmWWmzFHeP48eMVEhKi+++/vzzKLJHijvH06dOKiopSZGSkevTooW3btpVHucVSnDF++umniouLU3JyskJDQ9WkSRM9//zzysnJKa+yXVYaf3feeust9enTR35+fmVVZokUZ4xt2rTRxo0bHYdU9uzZo8WLF6tr167lUrOrijPGrKysfIdlfX199cUXX5RpreUpLS3NaZtIUmJiYpFf23kq7Kv5bXXs2DHl5OTk+4mA0NBQ/fjjj0Vax5NPPqmIiIh8O8gWxR1jRkaGateuraysLHl4eGjatGm6/fbby7rcYinOGL/44gu99dZb2rx5czlUWHLFGeMNN9ygt99+W82aNVNGRoYmTZqkNm3aaNu2bapTp055lO2S4oxxz549Wrlypfr27avFixdr165deuSRR3ThwgWNGTOmPMp2WUn/7nz99dfaunWr3nrrrbIqscSKM8Z7771Xx44dU7t27WSMUXZ2th566CE99dRT5VGyy4ozxsTERL3yyitq3769oqOjtWLFCs2dO9fqgO2q9PT0ArdJZmamfv/9d/n6+hZpPcywlLIXXnhB77//vubNm3dVnMzoCn9/f23evFnffPONnnvuOaWkpGj16tUVXVapOHXqlPr166c33nhDNWvWrOhyykxcXJzuu+8+NW/eXB06dNDcuXNVq1Yt/fOf/6zo0kpNbm6uQkJC9K9//UuxsbG6++67NWrUKM2YMaOiSyszb731lpo2bapWrVpVdCmlavXq1Xr++ec1bdo0fffdd5o7d64WLVqkZ599tqJLKzWvvfaarrvuOsXExMjLy0tDhgzRwIED5e7Ox/OlmGG5RM2aNeXh4aHDhw87LT98+LDCwsKu+NxJkybphRde0Oeff65mzZqVZZklUtwxuru7q2HDhpKk5s2b64cfflBqaqo6duxYluUWi6tj3L17t/bt26fu3bs7luXm5kqSPD09tWPHDkVHR5dt0S4qyWs1T5UqVdSiRQvt2rWrLEosseKMMTw8XFWqVJGHh4djWaNGjZSenq7z58/Ly8urTGsujpLsyzNnzuj999/X+PHjy7LEEivOGJ955hn169dPDzzwgCSpadOmOnPmjAYPHqxRo0ZZ96FenDHWqlVL8+fP17lz53T8+HFFRERoxIgRatCgQXmUXC7CwsIK3CYBAQFFnl2RmGHJx8vLS7GxsVqxYoVjWW5urlasWKG4uLjLPu/FF1/Us88+qyVLlqhly5blUWqxFXeMl8rNzVVWVlZZlFhiro4xJiZGW7Zs0ebNmx23O++8U7feeqs2b96syMjI8iy/SEpjP+bk5GjLli0KDw8vqzJLpDhjbNu2rXbt2uUInJL0008/KTw83MqwIpVsX86ZM0dZWVn629/+VtZllkhxxnj27Nl8oSQviBoLf7e3JPvRx8dHtWvXVnZ2tj7++GP16NGjrMstN3FxcU7bRJKWL1/u0ueNJC5rLsj7779vvL29zaxZs8z27dvN4MGDTVBQkOPyz379+pkRI0Y42r/wwgvGy8vLfPTRR06XGZ46daqihlAoV8f4/PPPm2XLlpndu3eb7du3m0mTJhlPT0/zxhtvVNQQCuXqGC91NVwl5OoYx40bZ5YuXWp2795tNm7caPr06WN8fHzMtm3bKmoIhXJ1jPv37zf+/v5myJAhZseOHWbhwoUmJCTETJgwoaKGUCTFfb22a9fO3H333eVdbrG4OsYxY8YYf39/89///tfs2bPHLFu2zERHR5vevXtX1BAK5eoY169fbz7++GOze/dus3btWnPbbbeZ+vXrm99++62CRlC4U6dOmU2bNplNmzYZSeaVV14xmzZtMj///LMxxpgRI0aYfv36OdrnXdb8+OOPmx9++MFMnTqVy5pL05QpU0zdunWNl5eXadWqlVm/fr3jsQ4dOpj+/fs77kdFRRlJ+W5jxowp/8Jd4MoYR40aZRo2bGh8fHxM9erVTVxcnHn//fcroGrXuDLGS10NgcUY18Y4bNgwR9vQ0FDTtWtXq7/vIY+r+/Grr74yrVu3Nt7e3qZBgwbmueeeM9nZ2eVctetcHeePP/5oJJlly5aVc6XF58oYL1y4YMaOHWuio6ONj4+PiYyMNI888ojVH+bGuDbG1atXm0aNGhlvb29To0YN069fP3Pw4MEKqLroVq1aVeBnXt64+vfvbzp06JDvOc2bNzdeXl6mQYMGxfq+IDdjLJxXAwAAuAjnsAAAAOsRWAAAgPUILAAAwHoEFgAAYD0CCwAAsB6BBQAAWI/AAgAArEdgAQAA1iOwAAAA6xFYAACA9QgsAADAev8fzRqbFp9I4rYAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(nearest_dist, bins=50)\n",
    "plt.title('The nearest distance between train and test')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.6599318403115871"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(np.array(nearest_dist) > 0.4).mean()"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# GOOD-HIV, Scaffold, Concept"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "data, _ = torch.load('../../data/raw/GOODHIV/scaffold/processed/concept_train.pt')\n",
    "train_smiles = data.smiles\n",
    "data, _ = torch.load('../../data/raw/GOODHIV/scaffold/processed/concept_test.pt')\n",
    "test_smiles = data.smiles"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "nearest_dist, nearest_idx = get_nearest_mols(test_smiles, train_smiles, return_idx=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'The nearest distance between train and test')"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAigAAAGzCAYAAAAFROyYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA6FUlEQVR4nO3deVxV1eL//zeDHJThIMogiaJoIam3wkJS0pJERaurZZYfQ7+lZWhXqW5aOWZhNmh6HW51rzb5qWx2SDPNoUQz03tNyzQ1NAM1AxyScf3+6Mf5eASFowwbfD0fj/N4cPZeZ6+19+Jw3qy91z5uxhgjAAAAC3Gv6QYAAACcjYACAAAsh4ACAAAsh4ACAAAsh4ACAAAsh4ACAAAsh4ACAAAsh4ACAAAsh4ACAAAsh4BSx61Zs0Zubm567733aropkLR//365ublpwYIFjmUTJ06Um5tbzTXKAkqOwdGjR2u6Kfj/de3aVV27dq3pZlyQiIgIDR48uKabgYtEQKmF3NzcKvRYs2ZNTTe1TpkzZ45TsKhJhw4d0sSJE7Vt27aaboplLVy4UDNmzKjpZlSZnTt3auLEidq/f39NN6VWOnXqlCZOnFjlfyeXLVumiRMnVmkddZVnTTcArnvjjTecnr/++utauXJlqeVt2rTR999/X51Nq9PmzJmjxo0bV/p/Zk8++aTGjBnj0msOHTqkSZMmKSIiQldddVWltqeuWLhwob777juNGjWqpptSJXbu3KlJkyapa9euioiIqPTtf/bZZ5W+TSs5deqUJk2aJElVOlK0bNkyzZ49m5ByAQgotdD//M//OD3fuHGjVq5cWWq5pEs2oJw8eVI+Pj413YwK8fT0lKcnb0VUHWOMTp8+rfr161f4NV5eXlXYIqB8nOK5RBQXF+vpp59W06ZN5e3trW7dumnPnj2lym3atEk9evSQ3W5XgwYN1KVLF3311Vflbr/kWpd333230ur5+eef9eCDD+qKK65Q/fr11ahRI91xxx2lhrQXLFggNzc3rV27Vg8++KCCg4PVtGlTx/pPP/1U8fHx8vHxkZ+fn5KSkrRjxw6nbWRmZmrIkCFq2rSpbDabmjRpoltvvdVRV0REhHbs2KG1a9c6TqGV919Xdna2Bg8eLLvdroCAACUnJys7O7tUubKuQVm5cqU6d+6sgIAA+fr66oorrtDjjz/uONbXXnutJGnIkCGO9pScflq/fr3uuOMONWvWTDabTeHh4Ro9erT++OMPpzoGDx4sX19f/fLLL7rtttvk6+uroKAgPfLIIyoqKnIqW1xcrJdeeknt2rWTt7e3goKC1KNHD33zzTdO5d58803FxMSofv36CgwM1IABA3TgwIHzHqczHT16VP3795e/v78aNWqkv/3tbzp9+nSpcuXV07VrVy1dulQ///yz4/hERETIGKPGjRsrNTXVad8CAgLk4eHh1D/PPvusPD09deLECceyH374QbfffrsCAwPl7e2tDh066JNPPinVvuzsbI0aNUrh4eGy2Wxq1aqVnn32WRUXFzvKlFyP9Pzzz+vll19WZGSkbDabrr32Wm3evPm8x2nBggW64447JEk33nhjqdO6ERER6t27t1asWKEOHTqofv36+uc//ylJmj9/vm666SYFBwfLZrMpOjpac+fOLVXH2deguPoeP5ur7+evvvpKqampCgoKko+Pj/7617/qyJEjTmWNMZoyZYqaNm2qBg0a6MYbbyz13i7L/v37FRQUJEmaNGmS4/idOcpRkb4uKCjQpEmT1Lp1a3l7e6tRo0bq3LmzVq5cKenP99js2bMlOZ+aR8Xwb9slYurUqXJ3d9cjjzyinJwcTZs2TQMHDtSmTZscZVavXq2ePXsqJiZGEyZMkLu7u+OP2fr163XddddVaz2bN2/Whg0bNGDAADVt2lT79+/X3Llz1bVrV+3cuVMNGjRwqvvBBx9UUFCQxo8fr5MnT0r683RYcnKyEhMT9eyzz+rUqVOaO3euOnfurK1btzqGxvv166cdO3Zo5MiRioiI0OHDh7Vy5UplZGQoIiJCM2bM0MiRI+Xr66snnnhCkhQSEnLO42CM0a233qovv/xSDzzwgNq0aaMPP/xQycnJ5R7DHTt2qHfv3mrfvr0mT54sm82mPXv2OAJcmzZtNHnyZI0fP17Dhg1TfHy8JOn666+XJC1atEinTp3S8OHD1ahRI3399deaNWuWDh48qEWLFjnVVVRUpMTERMXGxur555/X559/rhdeeEGRkZEaPny4o9y9996rBQsWqGfPnrrvvvtUWFio9evXa+PGjerQoYMk6emnn9a4cePUv39/3XfffTpy5IhmzZqlG264QVu3blVAQEC5+96/f39FREQoLS1NGzdu1MyZM/X777/r9ddfd5SpSD1PPPGEcnJydPDgQU2fPl2S5OvrKzc3N3Xq1Enr1q1zbO+///2vcnJy5O7urq+++kpJSUmS/gx6V199tXx9fR390qlTJ1122WUaM2aMfHx89O677+q2227T+++/r7/+9a+S/jx10KVLF/3yyy+6//771axZM23YsEFjx47Vr7/+Wuq6mIULF+r48eO6//775ebmpmnTpqlv377au3ev6tWrV+ZxuuGGG/TQQw9p5syZevzxx9WmTRvH70aJXbt26a677tL999+voUOH6oorrpAkzZ07V1deeaVuueUWeXp6avHixXrwwQdVXFyslJSUcvuoIu/xsrj6fh45cqQaNmyoCRMmaP/+/ZoxY4ZGjBihd955x1Fm/PjxmjJlinr16qVevXrp22+/Vffu3ZWfn3/etgQFBWnu3LkaPny4/vrXv6pv376SpPbt20uqeF9PnDhRaWlpuu+++3TdddcpNzdX33zzjb799lvdfPPNuv/++3Xo0KEyT8GjAgxqvZSUFHOurvziiy+MJNOmTRuTl5fnWP7SSy8ZSWb79u3GGGOKi4tN69atTWJioikuLnaUO3XqlGnRooW5+eabz9uGqqjn1KlTpepJT083kszrr7/uWDZ//nwjyXTu3NkUFhY6lh8/ftwEBASYoUOHOm0jMzPT2O12x/Lff//dSDLPPffceffxyiuvNF26dDlvmRIfffSRkWSmTZvmWFZYWGji4+ONJDN//nzH8gkTJjj13/Tp040kc+TIkXNuf/PmzaW2U6Ks45aWlmbc3NzMzz//7FiWnJxsJJnJkyc7lb366qtNTEyM4/nq1auNJPPQQw+V2m5JH+7fv994eHiYp59+2mn99u3bjaenZ6nlZys5BrfccovT8gcffNBIMv/5z39cricpKck0b968VF3PPfec8fDwMLm5ucYYY2bOnGmaN29urrvuOvPYY48ZY4wpKioyAQEBZvTo0Y7XdevWzbRr186cPn3aaf+vv/5607p1a8eyp556yvj4+Jgff/zRqd4xY8YYDw8Pk5GRYYwxZt++fUaSadSokTl27Jij3Mcff2wkmcWLF5/3mC1atMhIMl988UWpdc2bNzeSzPLly0utK+v3IzEx0bRs2dJpWZcuXZx+3yv6Hj8XV9/PCQkJTn8jRo8ebTw8PEx2drYxxpjDhw8bLy8vk5SU5FTu8ccfN5JM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G2/o0KFDjmsrpD9DbteuXfXPf/5Tv/76a6ntnfl7279/f6Wnp2vFihWlymVnZ6uwsPC8x6CizvU7cD5l/X7k5ORo/vz5ldKm8uq+mPfz2RISElSvXj3NmjXLabsVvXtwyayhs4+fK3199u+1r6+vWrVqVervRln1oHyMoEDSn/+xv/rqq+rZs6euvPJKDRkyRJdddpl++eUXffHFF/L399fixYurtZ7evXvrjTfekN1uV3R0tNLT0/X555+rUaNGFarL399fc+fO1aBBg3TNNddowIABCgoKUkZGhpYuXapOnTrpH//4h3788Ud169ZN/fv3V3R0tDw9PfXhhx8qKytLAwYMcGwvJiZGc+fO1ZQpU9SqVSsFBwef8/qWPn36qFOnThozZoz279+v6OhoffDBBxW6CHHy5Mlat26dkpKS1Lx5cx0+fFhz5sxR06ZNHddEREZGKiAgQPPmzZOfn598fHwUGxurqKgoRUZG6pFHHtEvv/wif39/vf/++xd1PcONN96oQYMGaebMmdq9e7d69Oih4uJirV+/XjfeeKNGjBihyMhITZkyRWPHjtX+/ft12223yc/PT/v27dOHH36oYcOG6ZFHHim3rn379umWW25Rjx49lJ6erjfffFN33323/vKXvzj2u6L1xMTE6J133lFqaqquvfZa+fr6qk+fPpKkuLg4eXp6ateuXRo2bJij/htuuMERKs8MKNKf4alz585q166dhg4dqpYtWyorK0vp6ek6ePCg/vOf/0iSHn30UX3yySfq3bu3Bg8erJiYGJ08eVLbt2/Xe++9p/3796tx48YX3B8lrrrqKnl4eOjZZ59VTk6ObDab4/4m59K9e3d5eXmpT58+uv/++3XixAm98sorCg4OLvPDuDJd7Pv5bCX37ElLS1Pv3r3Vq1cvbd26VZ9++mmFjm/9+vUVHR2td955R5dffrkCAwPVtm1btW3btsJ9HR0dra5duyomJkaBgYH65ptv9N5772nEiBGOemJiYiRJDz30kBITE+Xh4eH0dwXnUV3ThVB1KjLNeNGiRU7LS6Y4nj1NdevWraZv376mUaNGxmazmebNm5v+/fubVatWnbcNVVHP77//boYMGWIaN25sfH19TWJiovnhhx9M8+bNnaYQlkxL3Lx58znblpiYaOx2u/H29jaRkZFm8ODB5ptvvjHGGHP06FGT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cXFx8vHxUXJysiZPnlzZTQEAALXURQeUNWvWOD339vbW7NmzNXv27HO+pnnz5lq2bNnFVg0AAOoovosHAABYDgEFAABYDgEFAABYDgEFAABYDgEFAABYDgEFAABYTqXfBwWwoogxS2u6CQAAFxBQUOsRPgCg7uEUDwAAsBwCCgAAsBwCCgAAsBwCCgAAsBwCCgAAsBxm8QB1HLOcANRGjKAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADLIaAAAADL8azpBgDnEzFmaU03AQBQAxhBAQAAlkNAAQAAlkNAAQAAlkNAAQAAlkNAAQAAluNSQJk7d67at28vf39/+fv7Ky4uTp9++qlj/enTp5WSkqJGjRrJ19dX/fr1U1ZWltM2MjIylJSUpAYNGig4OFiPPvqoCgsLK2dvAABAneBSQGnatKmmTp2qLVu26JtvvtFNN92kW2+9VTt27JAkjR49WosXL9aiRYu0du1aHTp0SH379nW8vqioSElJScrPz9eGDRv02muvacGCBRo/fnzl7hUAAKjV3Iwx5mI2EBgYqOeee0633367goKCtHDhQt1+++2SpB9++EFt2rRRenq6OnbsqE8//VS9e/fWoUOHFBISIkmaN2+eHnvsMR05ckReXl4VqjM3N1d2u105OTny9/e/mObD4rgPinXsn5pUbpnK6q+K1AWg9nHl8/uCr0EpKirS22+/rZMnTyouLk5btmxRQUGBEhISHGWioqLUrFkzpaenS5LS09PVrl07RziRpMTEROXm5jpGYcqSl5en3NxcpwcAAKi7XA4o27dvl6+vr2w2mx544AF9+OGHio6OVmZmpry8vBQQEOBUPiQkRJmZmZKkzMxMp3BSsr5k3bmkpaXJbrc7HuHh4a42GwAA1CIu3+r+iiuu0LZt25STk6P33ntPycnJWrt2bVW0zWHs2LFKTU11PM/NzSWkANXMaqfbKtIeThUBtZfLAcXLy0utWrWSJMXExGjz5s166aWX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zZo1uuaaa2Sz2dSqVSstWLCgytspg0vC22+/bby8vMy///1vs2PHDjN06FATEBBgsrKyyix/9913m9mzZ5utW7ea77//3gwePNjY7XZz8ODBam553eFqH5TYt2+fueyyy0x8fLy59dZbq6exdZSrfZCXl2c6dOhgevXqZb788kuzb98+s2bNGrNt27Zqbnnd4WofvPXWW8Zms5m33nrL7Nu3z6xYscI0adLEjB49uppbXncsW7bMPPHEE+aDDz4wksyHH3543vJ79+41DRo0MKmpqWbnzp1m1qxZxsPDwyxfvrxK20lAuURcd911JiUlxfG8qKjIhIWFmbS0tAq9vrCw0Pj5+ZnXXnutqppY511IHxQWFprrr7/evPrqqyY5OZmAcpFc7YO5c+eali1bmvz8/OpqYp3nah+kpKSYm266yWlZamqq6dSpU5W281JRkYDy97//3Vx55ZVOy+68806TmJhYhS0zhlM8l4D8/Hxt2bJFCQkJjmXu7u5KSEhQenp6hbZx6tQpFRQUKDAwsKqaWaddaB9MnjxZwcHBuvfee6ujmXXahfTBJ598ori4OKWkpCgkJERt27bVM888o6Kioupqdp1yIX1w/fXXa8uWLY7TQHv37tWyZcvUq1evamkzpPT0dKc+k6TExMQKf35cqBq71T2qz9GjR1VUVFTqawRCQkL0ww8/VGgbjz32mMLCwkr9kqJiLqQPvvzyS/3rX//Stm3bqqGFdd+F9MHevXu1evVqDRw4UMuWLdOePXv04IMPqqCgQBMmTKiOZtcpF9IHd999t44eParOnTvLGKPCwkI98MADevzxx6ujyZCUmZlZZp/l5ubqjz/+UP369aukXkZQUK6pU6fq7bff1ocffihvb++abs4l4fjx4xo0aJBeeeUVNW7cuKabc8kqLi5WcHCwXn75ZcXExOjOO+/UE088oXnz5tV00y4Za9as0TPPPKM5c+bo22+/1QcffKClS5fqqaeeqummoYoxgnIJaNy4sTw8PJSVleW0PCsrS6Ghoed97fPPP6+pU6fq888/V/v27auymXWaq33w008/af/+/erTp49jWXFxsSTJ09NTu3btUmRkZNU2uo65kPdBkyZNVK9ePXl4eDiWtWnTRpmZmcrPz5eXl1eVtrmuuZA+GDdunAYNGqT77rtPktSuXTudPHlSw4YN0xNPPCF3d/7PrmqhoaFl9pm/v3+VjZ5IjKBcEry8vBQTE6NVq1Y5lhUXF2vVqlWKi4s75+umTZump556SsuXL1eHDh2qo6l1lqt9EBUVpe3bt2vbtm2Oxy233KIbb7xR27ZtU3h4eHU2v064kPdBp06dtGfPHkc4lKQff/xRTZo0IZxcgAvpg1OnTpUKISWB0fBdt9UiLi7Oqc8kaeXKlef9/KgUVXoJLizj7bffNjabzSxYsMDs3LnTDBs2zAQEBJjMzExjjDGDBg0yY8aMcZSfOnWq8fLyMu+995759ddfHY/jx4/X1C7Ueq72wdmYxXPxXO2DjIwM4+fnZ0aMGGF27dpllixZYoKDg82UKVNqahdqPVf7YMKECcbPz8/87//+r9m7d6/57LPPTGRkpOnfv39N7UKtd/z4cbN161azdetWI8m8+OKLZuvWrebnn382xhgzZswYM2jQIEf5kmnGjz76qPn+++/N7NmzmWaMyjVr1izTrFkz4+XlZa677jqzceNGx7ouXbqY5ORkx/PmzZsbSaUeEyZMqP6G1yGu9MHZCCiVw9U+2LBhg4mNjTU2m820bNnSPP3006awsLCaW123uNIHBQUFZuLEiSYyMtJ4e3ub8PBw8+CDD5rff/+9+hteR3zxxRdl/n0vOe7JycmmS5cupV5z1VVXGS8vL9OyZUszf/78Km+nmzGMkQEAAGvhGhQAAGA5BBQAAGA5BBQAAGA5BBQAAGA5BBQAAGA5BBQAAGA5BBQAAGA5BBQAAGA5BBQAAGA5BBQAAGA5BBQAAGA5/x/9Erx5lfSfOQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(nearest_dist, bins=50)\n",
    "plt.title('The nearest distance between train and test')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.6131314137690544"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(np.array(nearest_dist) > 0.4).mean()"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# GOOD-HIV, Size, Covariate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "data, _ = torch.load('../../data/raw/GOODHIV/size/processed/covariate_train.pt')\n",
    "train_smiles = data.smiles\n",
    "data, _ = torch.load('../../data/raw/GOODHIV/size/processed/covariate_test.pt')\n",
    "test_smiles = data.smiles"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "nearest_dist, nearest_idx = get_nearest_mols(test_smiles, train_smiles, return_idx=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'The nearest distance between train and test')"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAigAAAGzCAYAAAAFROyYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA1lElEQVR4nO3deVzVZf7//yeLICKLKIskgmKFpqaDSqSoJYWKlqONWX4MvZmWovNRpkVb3LJQc8rJj+lMzejU5FRWtqhZ7lqiU6aTaZlrpgZuAS6JAtfvD7+cn0dQFlku8HG/3c7txnmf67yv13lfHM6T670cF2OMEQAAgEVcq7oAAACAyxFQAACAdQgoAADAOgQUAABgHQIKAACwDgEFAABYh4ACAACsQ0ABAADWIaAAAADrEFBquLVr18rFxUXvvfdeVZcCSQcOHJCLi4sWLFjgWDZp0iS5uLhUXVEWKNgGx48fr+pS8P907dpVXbt2reoyyiQiIkKDBw+u6jJwjQgo1ZCLi0uJbmvXrq3qUmuUV1991SlYVKUjR45o0qRJ2rZtW1WXYq2FCxdq1qxZVV1Ghdm5c6cmTZqkAwcOVHUp1dLZs2c1adKkCv87uWzZMk2aNKlC+6ip3Ku6AJTem2++6XT/jTfe0IoVKwotb968ub7//vvKLK1Ge/XVV9WgQYNy/8/smWee0bhx40r1nCNHjmjy5MmKiIhQmzZtyrWemmLhwoX67rvvNGbMmKoupULs3LlTkydPVteuXRUREVHu6//888/LfZ02OXv2rCZPnixJFTpTtGzZMs2ZM4eQUgYElGrof/7nf5zub9q0SStWrCi0XNJ1G1DOnDkjb2/vqi6jRNzd3eXuzlsRFccYo3PnzsnLy6vEz/Hw8KjAioDisYvnOpGfn6/nn39ejRo1Uu3atdWtWzft2bOnULvNmzere/fu8vPzU506ddSlSxd9+eWXxa6/4FiXd999t9z6+emnnzRy5EjdfPPN8vLyUv369fWHP/yh0JT2ggUL5OLionXr1mnkyJEKCgpSo0aNHI9/+umniouLk7e3t3x8fJSYmKgdO3Y4rSM9PV1DhgxRo0aN5OnpqYYNG+ree+919BUREaEdO3Zo3bp1jl1oxf3XlZmZqcGDB8vPz0/+/v5KSkpSZmZmoXZFHYOyYsUKderUSf7+/qpbt65uvvlmPfXUU45t3b59e0nSkCFDHPUU7H7asGGD/vCHP6hx48by9PRUWFiYxo4dq99++82pj8GDB6tu3bo6fPiw+vTpo7p16yowMFCPPfaY8vLynNrm5+frL3/5i1q1aqXatWsrMDBQ3bt319dff+3U7l//+peio6Pl5eWlgIAADRgwQD///PNVt9Oljh8/rv79+8vX11f169fX//7v/+rcuXOF2hXXT9euXbV06VL99NNPju0TEREhY4waNGiglJQUp9fm7+8vNzc3p/GZPn263N3ddfr0aceyH374Qffdd58CAgJUu3ZttWvXTh9//HGh+jIzMzVmzBiFhYXJ09NTzZo10/Tp05Wfn+9oU3A80syZM/W3v/1NkZGR8vT0VPv27fXVV19ddTstWLBAf/jDHyRJd9xxR6HduhEREerVq5c+++wztWvXTl5eXvrrX/8qSZo/f77uvPNOBQUFydPTUy1atNDcuXML9XH5MSilfY9frrTv5y+//FIpKSkKDAyUt7e3fv/73+vYsWNObY0xmjp1qho1aqQ6derojjvuKPTeLsqBAwcUGBgoSZo8ebJj+106y1GSsb5w4YImT56sG2+8UbVr11b9+vXVqVMnrVixQtLF99icOXMkOe+aR8nwb9t1Ytq0aXJ1ddVjjz2mrKwszZgxQwMHDtTmzZsdbVavXq0ePXooOjpaEydOlKurq+OP2YYNG9ShQ4dK7eerr77Sxo0bNWDAADVq1EgHDhzQ3Llz1bVrV+3cuVN16tRx6nvkyJEKDAzUhAkTdObMGUkXd4clJSUpISFB06dP19mzZzV37lx16tRJW7dudUyN9+vXTzt27NDo0aMVERGho0ePasWKFTp48KAiIiI0a9YsjR49WnXr1tXTTz8tSQoODr7idjDG6N5779UXX3yhRx99VM2bN9fixYuVlJRU7DbcsWOHevXqpdatW2vKlCny9PTUnj17HAGuefPmmjJliiZMmKDhw4crLi5OknT77bdLkhYtWqSzZ89qxIgRql+/vv7zn/9o9uzZOnTokBYtWuTUV15enhISEhQTE6OZM2dq5cqV+vOf/6zIyEiNGDHC0W7o0KFasGCBevTooYcffli5ubnasGGDNm3apHbt2kmSnn/+eT377LPq37+/Hn74YR07dkyzZ89W586dtXXrVvn7+xf72vv376+IiAilpqZq06ZNeuWVV/Trr7/qjTfecLQpST9PP/20srKydOjQIb388suSpLp168rFxUUdO3bU+vXrHev79ttvlZWVJVdXV3355ZdKTEyUdDHotW3bVnXr1nWMS8eOHXXDDTdo3Lhx8vb21rvvvqs+ffro/fff1+9//3tJF3cddOnSRYcPH9Yjjzyixo0ba+PGjRo/frx++eWXQsfFLFy4UKdOndIjjzwiFxcXzZgxQ3379tW+fftUq1atIrdT586d9cc//lGvvPKKnnrqKTVv3tzxu1Fg165deuCBB/TII49o2LBhuvnmmyVJc+fO1S233KJ77rlH7u7u+uSTTzRy5Ejl5+crOTm52DEqyXu8KKV9P48ePVr16tXTxIkTdeDAAc2aNUujRo3SO++842gzYcIETZ06VT179lTPnj31zTff6O6779b58+evWktgYKDmzp2rESNG6Pe//7369u0rSWrdurWkko/1pEmTlJqaqocfflgdOnRQdna2vv76a33zzTe666679Mgjj+jIkSNF7oJHCRhUe8nJyeZKQ7lmzRojyTRv3tzk5OQ4lv/lL38xksz27duNMcbk5+ebG2+80SQkJJj8/HxHu7Nnz5omTZqYu+6666o1VEQ/Z8+eLdRPWlqakWTeeOMNx7L58+cbSaZTp04mNzfXsfzUqVPG39/fDBs2zGkd6enpxs/Pz7H8119/NZLMiy++eNXXeMstt5guXbpctU2BDz/80EgyM2bMcCzLzc01cXFxRpKZP3++Y/nEiROdxu/ll182ksyxY8euuP6vvvqq0HoKFLXdUlNTjYuLi/npp58cy5KSkowkM2XKFKe2bdu2NdHR0Y77q1evNpLMH//4x0LrLRjDAwcOGDc3N/P88887Pb59+3bj7u5eaPnlCrbBPffc47R85MiRRpL573//W+p+EhMTTXh4eKG+XnzxRePm5mays7ONMca88sorJjw83HTo0ME8+eSTxhhj8vLyjL+/vxk7dqzjed26dTOtWrUy586dc3r9t99+u7nxxhsdy5577jnj7e1tfvzxR6d+x40bZ9zc3MzBgweNMcbs37/fSDL169c3J0+edLT76KOPjCTzySefXHWbLVq0yEgya9asKfRYeHi4kWSWL19e6LGifj8SEhJM06ZNnZZ16dLF6fe9pO/xKynt+zk+Pt7pb8TYsWONm5ubyczMNMYYc/ToUePh4WESExOd2j311FNGkklKSrpqPceOHTOSzMSJEws9VtKxvvXWW01iYuJV+7na32dcHbt4rhNDhgxx2qdc8F/3vn37JEnbtm3T7t279eCDD+rEiRM6fvy4jh8/rjNnzqhbt25av3690/R0ZfRz6f7yCxcu6MSJE2rWrJn8/f31zTffFOp72LBhcnNzc9xfsWKFMjMz9cADDzj6OX78uNzc3BQTE6M1a9Y4+vHw8NDatWv166+/lmyDFmPZsmVyd3d3moVwc3PT6NGji31uwUzDRx99VKJtfrlLt9uZM2d0/Phx3X777TLGaOvWrYXaP/roo0734+LiHOMlSe+//75cXFw0ceLEQs8tmK7+4IMPlJ+fr/79+ztt65CQEN14442ObV2cy/+DL9hey5YtK7d+4uLilJeXp40bN0q6OFMSFxenuLg4bdiwQZL03XffKTMz0/H7e/LkSa1evVr9+/fXqVOnHP2eOHFCCQkJ2r17tw4fPizp4gxWXFyc6tWr51RjfHy88vLynGZvJOn+++9XvXr1nOqT5DQGZdGkSRMlJCQUWn7p70dWVpaOHz+uLl26aN++fcrKyip2vcW9x6+ktO/n4cOHO+0OKRi3n376SZK0cuVKnT9/XqNHj3Zqd60HRZdmrP39/bVjxw7t3r37mvpE0djFc51o3Lix0/2CP4gFH8gFb7Cr7YLIyspy+kNa0f389ttvSk1N1fz583X48GEZY5zaXK5JkyZO9wv6uvPOO4vsx9fXV5Lk6emp6dOn609/+pOCg4N12223qVevXnrooYcUEhJy1dd7JT/99JMaNmzo2D1QoGCa/Wruv/9+vf7663r44Yc1btw4devWTX379tV9990nV9fi/6c4ePCgJkyYoI8//rhQ4Lp8uxUcT3KpevXqOT1v7969Cg0NVUBAwBX73L17t4wxuvHGG4t8/Eq7Ki53+fMjIyPl6urqOE6hPPr53e9+pzp16mjDhg1KSEjQhg0bNHnyZIWEhGj27Nk6d+6cI6h06tRJkrRnzx4ZY/Tss8/q2WefLXK9R48e1Q033KDdu3fr22+/LbRdL213qeLeM2V1+fuhwJdffqmJEycqLS1NZ8+edXosKytLfn5+V11vWest7fu5uH4KgsrlvwuBgYHF/p26mtKM9ZQpU3TvvffqpptuUsuWLdW9e3cNGjTIsasI14aAcp24dGbhUgV/JAr+U3/xxReveNrq5R+2Fd3P6NGjNX/+fI0ZM0axsbHy8/OTi4uLBgwYUOTMwuVnKBS0efPNN4sMGpeeOTNmzBj17t1bH374oT777DM9++yzSk1N1erVq9W2bdtiXnX58vLy0vr167VmzRotXbpUy5cv1zvvvKM777xTn3/++RW3sXTxmJK77rpLJ0+e1JNPPqmoqCh5e3vr8OHDGjx4cKHtdrV1lUZ+fr5cXFz06aefFrnOkvzuFOXyAwrLo59atWopJiZG69ev1549e5Senq64uDgFBwfrwoUL2rx5szZs2KCoqChHyCjYbo899liRsxKS1KxZM0fbu+66S0888USR7W666San+8W9Z8qqqDN29u7dq27duikqKkovvfSSwsLC5OHhoWXLlunll18u0YxdWest7fu5orZLcUoz1p07d9bevXv10Ucf6fPPP9frr7+ul19+WfPmzdPDDz9coXVeDwgokHTxP1Xp4qxCfHy8Ff289957SkpK0p///GfHsnPnzhV5JszV+goKCirRa4qMjNSf/vQn/elPf9Lu3bvVpk0b/fnPf9a//vUvSYU/LK8mPDxcq1at0unTp50+NHft2lWi57u6uqpbt27q1q2bXnrpJb3wwgt6+umntWbNGsXHx1+xlu3bt+vHH3/UP//5Tz300EOO5QVnFZRFZGSkPvvsM508efKKsyiRkZEyxqhJkyaFPoBLY/fu3U7/+e/Zs0f5+fmOg5lL08/VxisuLk7Tp0/XypUr1aBBA0VFRcnFxUW33HKLNmzYoA0bNqhXr16O9k2bNpV0MdwU97sUGRmp06dPV+j7SCrd72OBTz75RDk5Ofr444+dZihKugvuWlzr+/ly4eHhki7+zhSMjyQdO3asRLNPV9p+pRlrSQoICNCQIUM0ZMgQnT59Wp07d9akSZMcAYWzdsqOY1AgSYqOjlZkZKRmzpzpdFplgctP76uMftzc3Ar9tzR79uxCp8BeSUJCgnx9ffXCCy/owoULV+zr7NmzhU5ljYyMlI+Pj3JychzLvL29S/zHtGfPnsrNzXU6fTMvL0+zZ88u9rknT54stKxgtqmgnoJrvFxeT8F/nZduN2OM/vKXv5So7qL069dPxhjHRa0uVdBP37595ebmpsmTJxcaM2OMTpw4UaK+Ck7JLFCwvXr06FHqfry9va94TEVcXJxycnI0a9YsderUyfEhEhcXpzfffFNHjhxxHFshXQy5Xbt21V//+lf98ssvhdZ36e9t//79lZaWps8++6xQu8zMTOXm5l51G5TUlX4Hrqao34+srCzNnz+/XGoqru9reT9fLj4+XrVq1dLs2bOd1lvSqwcXnDV0+fYrzVhf/ntdt25dNWvWrNDfjaL6QfGYQYGki/+xv/766+rRo4duueUWDRkyRDfccIMOHz6sNWvWyNfXV5988kml9tOrVy+9+eab8vPzU4sWLZSWlqaVK1eqfv36JerL19dXc+fO1aBBg/S73/1OAwYMUGBgoA4ePKilS5eqY8eO+r//+z/9+OOP6tatm/r3768WLVrI3d1dixcvVkZGhgYMGOBYX3R0tObOnaupU6eqWbNmCgoKuuLxLb1791bHjh01btw4HThwQC1atNAHH3xQooMQp0yZovXr1ysxMVHh4eE6evSoXn31VTVq1MhxTERkZKT8/f01b948+fj4yNvbWzExMYqKilJkZKQee+wxHT58WL6+vnr//fev6XiGO+64Q4MGDdIrr7yi3bt3q3v37srPz9eGDRt0xx13aNSoUYqMjNTUqVM1fvx4HThwQH369JGPj4/279+vxYsXa/jw4XrssceK7Wv//v2655571L17d6Wlpelf//qXHnzwQd16662O113SfqKjo/XOO+8oJSVF7du3V926ddW7d29JUmxsrNzd3bVr1y4NHz7c0X/nzp0dofLSgCJdDE+dOnVSq1atNGzYMDVt2lQZGRlKS0vToUOH9N///leS9Pjjj+vjjz9Wr169NHjwYEVHR+vMmTPavn273nvvPR04cEANGjQo83gUaNOmjdzc3DR9+nRlZWXJ09PTcX2TK7n77rvl4eGh3r1765FHHtHp06f12muvKSgoqMgP4/J0re/nyxVcsyc1NVW9evVSz549tXXrVn366acl2r5eXl5q0aKF3nnnHd10000KCAhQy5Yt1bJlyxKPdYsWLdS1a1dFR0crICBAX3/9td577z2NGjXK0U90dLQk6Y9//KMSEhLk5ubm9HcFV1FZpwuh4pTkNONFixY5LS84xfHy01S3bt1q+vbta+rXr288PT1NeHi46d+/v1m1atVVa6iIfn799VczZMgQ06BBA1O3bl2TkJBgfvjhBxMeHu50CmHBaYlfffXVFWtLSEgwfn5+pnbt2iYyMtIMHjzYfP31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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(nearest_dist, bins=50)\n",
    "plt.title('The nearest distance between train and test')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.40141378439787934"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(np.array(nearest_dist) > 0.4).mean()"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# GOOD-HIV, Size, Concept"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "data, _ = torch.load('../../data/raw/GOODHIV/size/processed/concept_train.pt')\n",
    "train_smiles = data.smiles\n",
    "data, _ = torch.load('../../data/raw/GOODHIV/size/processed/concept_test.pt')\n",
    "test_smiles = data.smiles"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[17:12:05] WARNING: not removing hydrogen atom without neighbors\n",
      "[17:12:05] WARNING: not removing hydrogen atom without neighbors\n"
     ]
    }
   ],
   "source": [
    "nearest_dist, nearest_idx = get_nearest_mols(test_smiles, train_smiles, return_idx=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'The nearest distance between train and test')"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAigAAAGzCAYAAAAFROyYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA3IUlEQVR4nO3df3zP9f7/8ft+2LDZZthGZmOqWZGaMCxiWYx06Ej5aFxEMc5h1Yl++JUa6kR8/DinzqFfPkql8iNCfp2MJM4REaGJNiSbH9nYnt8/+u59vG3Ye/bjubldL5f35eL9ej/fr+fj9Xq+3973PV+v1/vtZowxAgAAsIh7eRcAAABwKQIKAACwDgEFAABYh4ACAACsQ0ABAADWIaAAAADrEFAAAIB1CCgAAMA6BBQAAGAdAkolt3btWrm5uemDDz4o71Ig6eDBg3Jzc9O8efMcy8aNGyc3N7fyK8oC+fvg+PHj5V0K/r8OHTqoQ4cO5V1GsYSHh6t///7lXQauEQGlAnJzcyvSbe3ateVdaqUya9Ysp2BRno4cOaJx48Zp+/bt5V2KtebPn69p06aVdxmlZteuXRo3bpwOHjxY3qVUSGfPntW4ceNK/f/JZcuWady4caXaR2XlWd4FwHVvv/220/233npLK1euLLC8SZMm+u6778qytEpt1qxZql27don/Zfbcc89p1KhRLj3nyJEjGj9+vMLDw9W8efMSraeymD9/vr799luNGDGivEspFbt27dL48ePVoUMHhYeHl/j6P//88xJfp03Onj2r8ePHS1KpzhQtW7ZMM2fOJKQUAwGlAvqf//kfp/ubNm3SypUrCyyXdN0GlDNnzsjHx6e8yygST09PeXryVkTpMcbo3LlzqlatWpGf4+XlVYoVAVfHIZ7rRF5enl588UXVr19fVatWVadOnbRv374C7TZv3qx7771X/v7+ql69utq3b68vv/zyquvPP9fl/fffL7F+fvzxRw0dOlQ333yzqlWrplq1aumPf/xjgSntefPmyc3NTevWrdPQoUMVFBSk+vXrOx7/7LPPFBsbKx8fH9WoUUMJCQnauXOn0zrS09M1YMAA1a9fX97e3qpbt6569Ojh6Cs8PFw7d+7UunXrHIfQrvZX18mTJ9W/f3/5+/srICBAiYmJOnnyZIF2hZ2DsnLlSrVr104BAQHy9fXVzTffrGeeecaxr++8805J0oABAxz15B9+2rBhg/74xz+qQYMG8vb2VmhoqEaOHKnffvvNqY/+/fvL19dXhw8f1v333y9fX1/VqVNHTz75pHJzc53a5uXl6bXXXlPTpk1VtWpV1alTR/fee6++/vprp3bvvPOOoqOjVa1aNQUGBqpPnz46dOjQFffTxY4fP67evXvLz89PtWrV0p///GedO3euQLur9dOhQwctXbpUP/74o2P/hIeHyxij2rVrKzk52WnbAgIC5OHh4TQ+kydPlqenp06fPu1Ytnv3bj3wwAMKDAxU1apV1aJFC3366acF6jt58qRGjBih0NBQeXt7q3Hjxpo8ebLy8vIcbfLPR3rllVf097//XREREfL29tadd96pLVu2XHE/zZs3T3/84x8lSXfffXeBw7rh4eHq1q2bVqxYoRYtWqhatWr629/+JkmaO3euOnbsqKCgIHl7eysqKkqzZ88u0Mel56C4+h6/lKvv5y+//FLJycmqU6eOfHx89Ic//EHHjh1zamuM0cSJE1W/fn1Vr15dd999d4H3dmEOHjyoOnXqSJLGjx/v2H8Xz3IUZazPnz+v8ePH68Ybb1TVqlVVq1YttWvXTitXrpT0+3ts5syZkpwPzaNo+LPtOjFp0iS5u7vrySefVGZmpqZMmaK+fftq8+bNjjZffPGFunTpoujoaI0dO1bu7u6O/8w2bNigli1blmk/W7Zs0caNG9WnTx/Vr19fBw8e1OzZs9WhQwft2rVL1atXd+p76NChqlOnjsaMGaMzZ85I+v1wWGJiouLj4zV58mSdPXtWs2fPVrt27bRt2zbH1HivXr20c+dODR8+XOHh4Tp69KhWrlyptLQ0hYeHa9q0aRo+fLh8fX317LPPSpKCg4Mvux+MMerRo4f+9a9/6fHHH1eTJk20aNEiJSYmXnUf7ty5U926dVOzZs00YcIEeXt7a9++fY4A16RJE02YMEFjxozR4MGDFRsbK0lq06aNJGnhwoU6e/ashgwZolq1aumrr77SjBkz9NNPP2nhwoVOfeXm5io+Pl6tWrXSK6+8olWrVumvf/2rIiIiNGTIEEe7gQMHat68eerSpYseffRRXbhwQRs2bNCmTZvUokULSdKLL76o559/Xr1799ajjz6qY8eOacaMGbrrrru0bds2BQQEXHXbe/furfDwcKWkpGjTpk2aPn26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Evl/qb/88suXvWz10g/b0u5n+PDhmjt3rkaMGKGYmBj5+/vLzc1Nffr0KXRm4dIrFPLbvP3224UGjYuvnBkxYoS6d++ujz/+WCtWrNDzzz+vlJQUffHFF7r99tuvstUlq1q1alq/fr3WrFmjpUuXavny5XrvvffUsWNHff7555fdx9Lv55Tcc889OnHihJ5++mlFRkbKx8dHhw8fVv/+/QvstyutyxV5eXlyc3PTZ599Vug6i/LaKcylJxSWRD9VqlRRq1attH79eu3bt0/p6emKjY1VcHCwzp8/r82bN2vDhg2KjIx0hIz8/fbkk08WOishSY0bN3a0veeee/SXv/yl0HY33XST0/2rvWeKq7Ardn744Qd16tRJkZGRevXVVxUaGiovLy8tW7ZMU6dOLdKMXXHrdfX9XFr75WpcGeu77rpLP/zwgz755BN9/vnneuONNzR16lTNmTNHjz76aKnWeT0goEDS73+pSr/PKsTFxVnRzwcffKDExET99a9/dSw7d+5coVfCXKmvoKCgIm1TRESEnnjiCT3xxBPau3evmjdvrr/+9a965513JBX8sLySsLAwrV69WqdPn3b60NyzZ0+Rnu/u7q5OnTqpU6dOevXVV/XSSy/p2Wef1Zo1axQXF3fZWnbs2KHvv/9eb775ph555BHH8vyrCoojIiJCK1as0IkTJy47ixIRESFjjBo2bFjgA9gVe/fudfrLf9++fcrLy3OczOxKP1car9jYWE2ePFmrVq1S7dq1FRkZKTc3N91yyy3asGGDNmzYoG7dujnaN2rUSNLv4eZqr6WIiAidPn26VN9Hkmuvx3yLFy9Wdna2Pv30U6cZiqIegrsW1/p+vlRYWJik318z+eMjSceOHSvS7NPl9p8rYy1JgYGBGjBggAYMGKDTp0/rrrvu0rhx4xwBhat2io9zUCBJio6OVkREhF555RWnyyrzXXp5X1n04+HhUeCvpRkzZhS4BPZy4uPj5efnp5deeknnz5+/bF9nz54tcClrRESEatSooezsbMcyHx+fIv9n2rVrV124cMHp8s3c3FzNmDHjqs89ceJEgWX5s0359eR/x8ul9eT/1XnxfjPG6LXXXitS3YXp1auXjDGOL7W6WH4/PXv2lIeHh8aPH19gzIwx+uWXX4rUV/4lmfny91eXLl1c7sfHx+ey51TExsYqOztb06ZN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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(nearest_dist, bins=50)\n",
    "plt.title('The nearest distance between train and test')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.5988598574821853"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(np.array(nearest_dist) > 0.4).mean()"
   ]
  },
  {
   "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.9"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
