{
 "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 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": [
    "# MolData"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1580825/2157940996.py:5: DtypeWarning: Columns (1) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  data = pd.read_csv('../../../Transilico-MolData-7300272/Data/all_molecular_data.csv')\n"
     ]
    },
    {
     "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>PUBCHEM_CID</th>\n",
       "      <th>activity_1554</th>\n",
       "      <th>activity_2732</th>\n",
       "      <th>activity_1085</th>\n",
       "      <th>activity_1236</th>\n",
       "      <th>activity_1274</th>\n",
       "      <th>activity_781</th>\n",
       "      <th>activity_422</th>\n",
       "      <th>activity_1224905</th>\n",
       "      <th>...</th>\n",
       "      <th>activity_743199</th>\n",
       "      <th>activity_743219</th>\n",
       "      <th>activity_743226</th>\n",
       "      <th>activity_743227</th>\n",
       "      <th>activity_743228</th>\n",
       "      <th>activity_743239</th>\n",
       "      <th>activity_743240</th>\n",
       "      <th>activity_743241</th>\n",
       "      <th>activity_743242</th>\n",
       "      <th>split</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Cc1ccccc1Cn1c(=O)n(-c2ccccc2)c(=O)c2ccc(C(=O)N...</td>\n",
       "      <td>15944820</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>CCN(CC)S(=O)(=O)c1csc(C(=O)Nc2ccccn2)c1</td>\n",
       "      <td>648487</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>COc1ccc(/C=C(\\NC(=O)c2ccc(Cl)cc2)C(=O)NCCCN2CC...</td>\n",
       "      <td>2891740</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>COc1cccc(OCc2nnc(SCC(=O)N3c4ccccc4Sc4ccc(Cl)cc...</td>\n",
       "      <td>1134840</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>O=C(Oc1ccc(N(Cc2cccs2)C2=NS(=O)(=O)c3ccccc32)c...</td>\n",
       "      <td>990838</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1429984</th>\n",
       "      <td>CO/N=C1/C[C@]2(C[C@@H]3C[C@@H](C/C=C(\\C)C[C@@H...</td>\n",
       "      <td>44134376</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1429985</th>\n",
       "      <td>CO/N=C(/C(=O)OC)c1ccccc1CO/N=C(\\C)c1cccc(C(F)(...</td>\n",
       "      <td>11664966</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1429986</th>\n",
       "      <td>CCOP(=O)(OCC)SCS(=O)(=O)C(C)(C)C</td>\n",
       "      <td>14671598</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1429987</th>\n",
       "      <td>CCCC[Sn](CCCC)CCCC</td>\n",
       "      <td>3032732</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1429988</th>\n",
       "      <td>O=S(=O)([O-])c1ccc(N=Nc2cc(S(=O)(=O)[O-])c3ccc...</td>\n",
       "      <td>19118</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1429989 rows × 603 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                    smiles PUBCHEM_CID  \\\n",
       "0        Cc1ccccc1Cn1c(=O)n(-c2ccccc2)c(=O)c2ccc(C(=O)N...    15944820   \n",
       "1                  CCN(CC)S(=O)(=O)c1csc(C(=O)Nc2ccccn2)c1      648487   \n",
       "2        COc1ccc(/C=C(\\NC(=O)c2ccc(Cl)cc2)C(=O)NCCCN2CC...     2891740   \n",
       "3        COc1cccc(OCc2nnc(SCC(=O)N3c4ccccc4Sc4ccc(Cl)cc...     1134840   \n",
       "4        O=C(Oc1ccc(N(Cc2cccs2)C2=NS(=O)(=O)c3ccccc32)c...      990838   \n",
       "...                                                    ...         ...   \n",
       "1429984  CO/N=C1/C[C@]2(C[C@@H]3C[C@@H](C/C=C(\\C)C[C@@H...    44134376   \n",
       "1429985  CO/N=C(/C(=O)OC)c1ccccc1CO/N=C(\\C)c1cccc(C(F)(...    11664966   \n",
       "1429986                   CCOP(=O)(OCC)SCS(=O)(=O)C(C)(C)C    14671598   \n",
       "1429987                                 CCCC[Sn](CCCC)CCCC     3032732   \n",
       "1429988  O=S(=O)([O-])c1ccc(N=Nc2cc(S(=O)(=O)[O-])c3ccc...       19118   \n",
       "\n",
       "         activity_1554  activity_2732  activity_1085  activity_1236  \\\n",
       "0                  0.0            1.0            0.0            0.0   \n",
       "1                  0.0            0.0            0.0            0.0   \n",
       "2                  0.0            NaN            NaN            NaN   \n",
       "3                  0.0            0.0            0.0            0.0   \n",
       "4                  0.0            0.0            0.0            0.0   \n",
       "...                ...            ...            ...            ...   \n",
       "1429984            NaN            NaN            NaN            NaN   \n",
       "1429985            NaN            NaN            NaN            NaN   \n",
       "1429986            NaN            NaN            NaN            NaN   \n",
       "1429987            NaN            NaN            NaN            NaN   \n",
       "1429988            NaN            NaN            NaN            NaN   \n",
       "\n",
       "         activity_1274  activity_781  activity_422  activity_1224905  ...  \\\n",
       "0                  0.0           0.0           NaN               NaN  ...   \n",
       "1                  0.0           0.0           0.0               NaN  ...   \n",
       "2                  NaN           NaN           NaN               NaN  ...   \n",
       "3                  0.0           0.0           NaN               NaN  ...   \n",
       "4                  0.0           0.0           NaN               NaN  ...   \n",
       "...                ...           ...           ...               ...  ...   \n",
       "1429984            NaN           NaN           NaN               NaN  ...   \n",
       "1429985            NaN           NaN           NaN               NaN  ...   \n",
       "1429986            NaN           NaN           NaN               NaN  ...   \n",
       "1429987            NaN           NaN           NaN               NaN  ...   \n",
       "1429988            NaN           NaN           NaN               NaN  ...   \n",
       "\n",
       "         activity_743199  activity_743219  activity_743226  activity_743227  \\\n",
       "0                    NaN              NaN              NaN              NaN   \n",
       "1                    NaN              NaN              NaN              NaN   \n",
       "2                    NaN              NaN              NaN              NaN   \n",
       "3                    NaN              NaN              NaN              NaN   \n",
       "4                    NaN              NaN              NaN              NaN   \n",
       "...                  ...              ...              ...              ...   \n",
       "1429984              NaN              NaN              NaN              NaN   \n",
       "1429985              NaN              NaN              NaN              NaN   \n",
       "1429986              NaN              NaN              NaN              NaN   \n",
       "1429987              NaN              NaN              NaN              NaN   \n",
       "1429988              NaN              NaN              NaN              NaN   \n",
       "\n",
       "         activity_743228  activity_743239  activity_743240  activity_743241  \\\n",
       "0                    NaN              NaN              NaN              NaN   \n",
       "1                    NaN              NaN              NaN              NaN   \n",
       "2                    NaN              NaN              NaN              NaN   \n",
       "3                    NaN              NaN              NaN              NaN   \n",
       "4                    NaN              NaN              NaN              NaN   \n",
       "...                  ...              ...              ...              ...   \n",
       "1429984              NaN              NaN              NaN              NaN   \n",
       "1429985              NaN              NaN              NaN              NaN   \n",
       "1429986              NaN              NaN              NaN              NaN   \n",
       "1429987              NaN              NaN              NaN              NaN   \n",
       "1429988              NaN              NaN              NaN              NaN   \n",
       "\n",
       "         activity_743242  split  \n",
       "0                    NaN  train  \n",
       "1                    NaN  train  \n",
       "2                    NaN  train  \n",
       "3                    NaN  train  \n",
       "4                    NaN  train  \n",
       "...                  ...    ...  \n",
       "1429984              NaN  train  \n",
       "1429985              NaN  train  \n",
       "1429986              NaN  train  \n",
       "1429987              NaN  train  \n",
       "1429988              NaN  train  \n",
       "\n",
       "[1429989 rows x 603 columns]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Note: this dataset is too large to be loaded into the repository.\n",
    "# You can find the dataset in the paper: https://jcheminf.biomedcentral.com/articles/10.1186/s13321-022-00590-y\n",
    "# Or at the official Zenodo: https://zenodo.org/record/6021605\n",
    "\n",
    "data = pd.read_csv('../../../Transilico-MolData-7300272/Data/all_molecular_data.csv') \n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0    302757\n",
       "1.0       516\n",
       "Name: activity_1554, dtype: int64"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data['activity_1554'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "train         1143981\n",
       "test           143004\n",
       "validation     143004\n",
       "Name: split, dtype: int64"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data['split'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_smiles = data[data['split'] == 'train']['smiles'][:30000]\n",
    "test_smiles = data[data['split'] == 'test']['smiles'][:30000]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_smiles = train_smiles.to_list()\n",
    "test_smiles = test_smiles.to_list()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "nearest_dist, nearest_idx = get_nearest_mols(test_smiles, train_smiles, return_idx=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'The nearest distance between train and test')"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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S7uf4cOHa968eRoxYoSioqLk5+cnNzc39erVK8+ZicuvsMhp88477+QZRC698mfEiBHq1q2bPv74Y61YsUJPP/20pkyZojVr1ujWW28t4FmXLG9vb61fv15r167V0qVLtXz5ci1cuFB33XWXVq5cme8+ln4/p+Xuu+/W8ePH9eSTTyoiIkI+Pj46ePCg+vfvn2u/XWlbRZGdnS03Nzd9/vnneW6zMK+dvFx+wmNJ9FOpUiW1bNlS69ev1549e5Samqro6GgFBgbqwoUL2rJlizZs2KCIiAhnCMnZb6NGjcpzVkOSGjRo4Gx7991364knnsiz3Y033uhyv6D3THHldcXRTz/9pA4dOigiIkIvvviiQkJC5OXlpWXLlumll14q1Ixfcest6vu5tPZLQYoy1m3atNFPP/2kTz75RCtXrtQbb7yhl156SXPnztWgQYNKtc6rHQEGhRYeHi7p91mJmJiYCtHPBx98oH79+umFF15wLjt79myeV/Jcqa+AgIBCPafw8HA99thjeuyxx7R7927dcssteuGFF/Svf/1LUu4P0ysJDQ3V6tWrderUKZcP1V27dhXq8e7u7urQoYM6dOigF198Uc8995zGjh2rtWvXKiYmJt9atm/frh9//FFvvfWWHnroIefynKsiiiM8PFwrVqzQ8ePH852FCQ8PlzFG9erVy/UBXRS7d+92mTnYs2ePsrOznSdbF6WfK41XdHS0pk2bplWrVqlWrVqKiIiQm5ubmjRpog0bNmjDhg3q2rWrs339+vUl/R5+CnothYeH69SpU6X6PpKK9nrM8emnn+rcuXNasmSJywxHYQ/x/RF/9P18udDQUEm/v2ZyxkeSjhw5UqjZq/z2X1HGWpJq1KihAQMGaMCAATp16pTatGmjCRMmOAMMVx0VD+fAoNAiIyMVHh6u559/3uWy0RyXX75YFv14eHjk+mtr1qxZuS7xzU9sbKx8fX313HPP6cKFC/n2debMmVyX6oaHh6tatWo6d+6cc5mPj0+h/7Pt0qWLLl686HJ5alZWlmbNmlXgY48fP55rWc5sVU49Od9xc3k9OX+1XrrfjDF6+eWXC1V3Xnr06CFjjPNLvy6V00/37t3l4eGhiRMn5hozY4yOHTtWqL5yLjnNkbO/OnfuXOR+fHx88j2nIzo6WufOndPMmTPVunVr54dMdHS03nnnHR06dMh5bof0ewhu166d/vGPf+jXX3/Ntb1LX7c9e/ZUUlKSVqxYkatdenq6Ll68eMV9UFj5vQauJK/XR0ZGhubNm1ciNRXU9x95P18uJiZGlSpV0qxZs1y2W9hvX8656uny/VeUsb78dV21alU1aNAg1/8befWDK2MGBoXm7u6uN954Q507d1aTJk00YMAAXXfddTp48KDWrl0rX19fffrpp2XaT9euXfXOO+/Iz89PjRs3VlJSklatWqWaNWsWqi9fX1/NmTNHffv21W233aZevXqpdu3a2r9/v5YuXapWrVrp73//u3788Ud16NBBPXv2VOPGjeXp6anFixcrLS1NvXr1cm4vMjJSc+bM0eTJk9WgQQMFBATke35Nt27d1KpVK40ePVopKSlq3LixPvroo0KdJDlp0iStX79ecXFxCg0N1eHDh/Xqq6+qbt26znMywsPD5e/vr7lz56patWry8fFRy5YtFRERofDwcI0aNUoHDx6Ur6+vPvzwwz90PkX79u3Vt29fvfLKK9q9e7c6deqk7OxsbdiwQe3bt9ewYcMUHh6uyZMna8yYMUpJSdF9992natWqad++fVq8eLGGDBmiUaNGFdjXvn37dM8996hTp05KSkrSv/71L/Xu3Vs333yz83kXtp/IyEgtXLhQCQkJuv3221W1alV169ZNkhQVFSVPT0/t2rVLQ4YMcfbfpk0bZ+i8NMBIv4er1q1bq2nTpho8eLDq16+vtLQ0JSUl6cCBA/rvf/8rSXr88ce1ZMkSde3aVf3791dkZKROnz6t7du364MPPlBKSopq1apV7PHIccstt8jDw0PTpk1TRkaGHA6H8/td8tOxY0d5eXmpW7duevjhh3Xq1Cm9/vrrCggIyPPDuiT90ffz5XK+s2jKlCnq2rWrunTpom3btunzzz8v1P719vZW48aNtXDhQt14442qUaOGbrrpJt10002FHuvGjRurXbt2ioyMVI0aNfT111/rgw8+0LBhw5z9REZGSpL++te/KjY2Vh4eHi7/ryAfZXW5E8pXYS6jXrRokcvynEs4L78Md9u2baZ79+6mZs2axuFwmNDQUNOzZ0+zevXqK9ZQGv2cOHHCDBgwwNSqVctUrVrVxMbGmh9++MGEhoa6XCKZc9nlV199lW9tsbGxxs/Pz1SuXNmEh4eb/v37m6+//toYY8zRo0dNfHy8iYiIMD4+PsbPz8+0bNnSvP/++y7bSU1NNXFxcaZatWpGUoGXVB87dsz07dvX+Pr6Gj8/P9O3b1+zbdu2Ai+jXr16tbn33ntNcHCw8fLyMsHBwebBBx/MdVnuJ598Yho3bmw8PT1dtrlz504TExNjqlatamrVqmUGDx5s/vvf/+bqt1+/fsbHxydX3ZfXY8zvl4DPmDHDREREGC8vL1O7dm3TuXNns3XrVpd2H374oWndurXx8fExPj4+JiIiwsTHx5tdu3ZdcV/l9Llz505z//33m2rVqpnq1aubYcOGmd9++y1X+8L0c+rUKdO7d2/j7+9vJOW6pPr22283ksyWLVucyw4cOGAkmZCQkDzr/Omnn8xDDz1kgoKCTKVKlcx1111nunbtaj744AOXdidPnjRjxowxDRo0MF5eXqZWrVrmzjvvNM8//7w5f/68Meb/3ht5Xb6vfC7vvdzrr79u6tevbzw8PFwuqQ4NDc338t4lS5aYZs2amcqVK5uwsDAzbdo08+abbxpJZt++fc52+V1GXdj3+OX+6Ps5p/9LLxvPysoyEydONHXq1DHe3t6mXbt25rvvvsu1zfxs2rTJREZGGi8vr1z7vDBjPXnyZNOiRQvj7+9vvL29TUREhHn22WedY2zM7++d4cOHm9q1axs3NzcuqS4kN2NK+WwnAACAEsY5MAAAwDoEGAAAYB0CDAAAsA4BBgAAWIcAAwAArEOAAQAA1rlqv8guOztbhw4dUrVq1fiaZgAALGGM0cmTJxUcHHzFH6e9agPMoUOHFBISUt5lAACAYvjll19Ut27dfNdftQGmWrVqkn7fAb6+vuVcDQAAKIzMzEyFhIQ4P8fzc9UGmJzDRr6+vgQYAAAsU9DpH5zECwAArEOAAQAA1iHAAAAA6xBgAACAdQgwAADAOgQYAABgHQIMAACwDgEGAABYhwADAACsQ4ABAADWIcAAAADrEGAAAIB1CDAAAMA6BBgAAGAdz/IuAED5Cxu9tMA2KVPjyqASACgcZmAAAIB1CDAAAMA6BBgAAGAdAgwAALAOAQYAAFiHAAMAAKxDgAEAANYhwAAAAOsQYAAAgHUIMAAAwDoEGAAAYB0CDAAAsA4BBgAAWIcAAwAArEOAAQAA1iHAAAAA6xBgAACAdQgwAADAOgQYAABgHQIMAACwDgEGAABYhwADAACsQ4ABAADWIcAAAADrEGAAAIB1CDAAAMA6RQowU6ZM0e23365q1aopICBA9913n3bt2uXS5uzZs4qPj1fNmjVVtWpV9ejRQ2lpaS5t9u/fr7i4OFWpUkUBAQF6/PHHdfHiRZc269at02233SaHw6EGDRpo/vz5xXuGAADgqlOkAPPFF18oPj5emzdvVmJioi5cuKCOHTvq9OnTzjYjR47Up59+qkWLFumLL77QoUOH1L17d+f6rKwsxcXF6fz589q0aZPeeustzZ8/X+PGjXO22bdvn+Li4tS+fXslJydrxIgRGjRokFasWFECTxkAANjOzRhjivvgI0eOKCAgQF988YXatGmjjIwM1a5dWwsWLND9998vSfrhhx/UqFEjJSUl6Y477tDnn3+url276tChQwoMDJQkzZ07V08++aSOHDkiLy8vPfnkk1q6dKm+++47Z1+9evVSenq6li9fXqjaMjMz5efnp4yMDPn6+hb3KQLXhLDRSwtskzI1rgwqAXCtK+zn9x86ByYjI0OSVKNGDUnS1q1bdeHCBcXExDjbRERE6Prrr1dSUpIkKSkpSU2bNnWGF0mKjY1VZmamduzY4Wxz6TZy2uRsIy/nzp1TZmamyw0AAFydih1gsrOzNWLECLVq1Uo33XSTJCk1NVVeXl7y9/d3aRsYGKjU1FRnm0vDS876nHVXapOZmanffvstz3qmTJkiPz8/5y0kJKS4Tw0AAFRwxQ4w8fHx+u677/Tee++VZD3FNmbMGGVkZDhvv/zyS3mXBAAASolncR40bNgwffbZZ1q/fr3q1q3rXB4UFKTz588rPT3dZRYmLS1NQUFBzjZffvmly/ZyrlK6tM3lVy6lpaXJ19dX3t7eedbkcDjkcDiK83QAAIBlijQDY4zRsGHDtHjxYq1Zs0b16tVzWR8ZGalKlSpp9erVzmW7du3S/v37FRUVJUmKiorS9u3bdfjwYWebxMRE+fr6qnHjxs42l24jp03ONgAAwLWtSDMw8fHxWrBggT755BNVq1bNec6Kn5+fvL295efnp4EDByohIUE1atSQr6+vhg8frqioKN1xxx2SpI4dO6px48bq27evpk+frtTUVP3tb39TfHy8cwblkUce0d///nc98cQT+p//+R+tWbNG77//vpYuLfhKCQAAcPUr0gzMnDlzlJGRoXbt2qlOnTrO28KFC51tXnrpJXXt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P2bfvn1m3bp1Jjk5uYwrvzYVdbzeffdd43A4zLvvvmv27dtnVqxYYerUqWNGjhxZxpVfm5YtW2bGjh1rPvroIyPJLF68+Irt9+7da6pUqWISEhLMzp07zaxZs4yHh4dZvnx5qdVIgCklLVq0MPHx8c77WVlZJjg42EyZMqVQj7948aKpVq2aeeutt0qrRFymOGN28eJFc+edd5o33njD9OvXjwBThoo6XnPmzDH169c358+fL6sScYmijld8fLy56667XJYlJCSYVq1alWqdyK0wAeaJJ54wTZo0cVn2wAMPmNjY2FKri0NIpeD8+fPaunWrYmJinMvc3d0VExOjpKSkQm3jzJkzunDhgmrUqFFaZeISxR2zSZMmKSAgQAMHDiyLMvG/ijNeS5YsUVRUlOLj4xUYGKibbrpJzz33nLKyssqq7GtWccbrzjvv1NatW52Hmfbu3atly5apS5cuZVIziiYpKcllfCUpNja20J95xVFhf0rAZkePHlVWVlaunz0IDAzUDz/8UKhtPPnkkwoODs71gkDpKM6Y/ec//9E///lPJScnl0GFuFRxxmvv3r1as2aN+vTpo2XLlmnPnj0aOnSoLly4oPHjx5dF2des4oxX7969dfToUbVu3VrGGF28eFGPPPKInnrqqbIoGUWUmpqa5/hmZmbqt99+k7e3d4n3yQxMBTR16lS99957Wrx4sSpXrlze5SAPJ0+eVN++ffX666+rVq1a5V0OCiE7O1sBAQF67bXXFBkZqQceeEBjx47V3Llzy7s05GHdunV67rnn9Oqrr+qbb77RRx99pKVLl+qZZ54p79JQQTADUwpq1aolDw8PpaWluSxPS0tTUFDQFR/7/PPPa+rUqVq1apWaNWtWmmXiEkUds59++kkpKSnq1q2bc1l2drYkydPTU7t27VJ4eHjpFn0NK857rE6dOqpUqZI8PDycyxo1aqTU1FSdP39eXl5epVrztaw44/X000+rb9++GjRokCSpadOmOn36tIYMGaKxY8fK3Z2/vyuSoKCgPMfX19e3VGZfJGZgSoWXl5ciIyO1evVq57Ls7GytXr1aUVFR+T5u+vTpeuaZZ7R8+XI1b968LErF/yrqmEVERGj79u1KTk523u655x61b99eycnJCgkJKcvyrznFeY+1atVKe/bscQZNSfrxxx9Vp04dwkspK854nTlzJldIyQmfht8grnCioqJcxleSEhMTr/iZ94eV2unB17j33nvPOBwOM3/+fLNz504zZMgQ4+/vb1JTU40xxvTt29eMHj3a2X7q1KnGy8vLfPDBB+bXX3913k6ePFleT+GaU9QxuxxXIZWtoo7X/v37TbVq1cywYcPMrl27zGeffWYCAgLM5MmTy+spXFOKOl7jx4831apVM//+97/N3r17zcqVK014eLjp2bNneT2Fa8rJkyfNtm3bzLZt24wk8+KLL5pt27aZn3/+2RhjzOjRo03fvn2d7XMuo3788cfN999/b2bPns1l1DabNWuWuf76642Xl5dp0aKF2bx5s3Nd27ZtTb9+/Zz3Q0NDjaRct/Hjx5d94dewoozZ5QgwZa+o47Vp0ybTsmVL43A4TP369c2zzz5rLl68WMZVX7uKMl4XLlwwEyZMMOHh4aZy5comJCTEDB061Jw4caLsC78GrV27Ns/PpJwx6tevn2nbtm2ux9xyyy3Gy8vL1K9f38ybN69Ua3Qzhrk4AABgF86BAQAA1iHAAAAA6xBgAACAdQgwAADAOgQYAABgHQIMAACwDgEGAABYhwADAACsQ4ABAADWIcAAAADrEGAAAIB1/j/9eDL8gNQqLAAAAABJRU5ErkJggg==",
      "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": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8753"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(np.array(nearest_dist) > 0.4).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[608,\n",
       " 2294,\n",
       " 3399,\n",
       " 3621,\n",
       " 5247,\n",
       " 7234,\n",
       " 7290,\n",
       " 8210,\n",
       " 8936,\n",
       " 8962,\n",
       " 9658,\n",
       " 10539,\n",
       " 10578,\n",
       " 10964,\n",
       " 11356,\n",
       " 12245,\n",
       " 12664,\n",
       " 13032,\n",
       " 13117,\n",
       " 13341,\n",
       " 14591,\n",
       " 15143,\n",
       " 15195,\n",
       " 18707,\n",
       " 21844,\n",
       " 24095,\n",
       " 24114,\n",
       " 24453,\n",
       " 27774,\n",
       " 28325,\n",
       " 29747]"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "similar_idx = []\n",
    "for i, sim in enumerate(nearest_dist):\n",
    "    if sim > 0.99:\n",
    "        similar_idx.append(i)\n",
    "similar_idx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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DhipWbNmP/3006BBg9LS0oKDgxcsWGB0ReWYNGnSqVOnevfuPWXKFKNrAQATINthJzycChjM09PzscceS0tL27x587JlyxxtHMG33377xhtv1KtXb82aNb6+vkaXAwDmQLbDHmjcAeM57DiCs2fPPvzww9nZ2R9//HHfvn2NLgcAzIRsh83xcCoc2pEjR9q1a2d0FfpxqHEESqmQkJDVq1f369dvzZo1FovFwGIAOBOy3cBiyHZTo3GHgzpx4kSPHj0uXLhgsViaNGny5JNPBgYGdurUqXPnzl5eXkZXZ0eOM47g008//ctf/uLr67tr1y4/Pz+jygDgTMh2sh21QeMOR5SVldW8efP09PSym7y9vTt16tStW7eAgICuXbt26dKlYcOG+ldoV2fOnBk8ePCOHTt8fHyWL19+77336l/D0aNHAwICrl27tmjRopEjR+pfAADnQ7aT7aglGnc4olGjRi1atMhqtW7atMnNzW3Hjh3Z2dnbtm3btm3b/v37i4qKSu7s5+cXGBiordn4+/v7+/s7wYW/a9eujRo1atWqVV5eXl999dXjjz+u59mLior69OmTlJQUFhY2d+5cPU8NwImR7WQ7aonGHQ7nnXfeefXVV729vT/77LOwsLBSW3///feDBw/u2bNHy/odO3ZkZWWV3KFRo0adO3cuzvru3bub9FVwhYWFzz///Mcff2yxWN544w09nyN/++23X3vttWbNmu3evbtJkya6nReAEyPbNWQ7aoPGHY5l8eLFo0aNEpGlS5cOHTr0hvsXFBQcOHBg7969Wtxv3br1/PnzJXfw8PBo3759cdb36tXLXHOvPvzwwxdffLGoqGj8+PGzZ8/28PCw9xlTUlJ69uyZn5+/evXqAQMG2Pt0AFwB2V4K2Y6aoXGHA9m6dWufPn2ysrJmzpw5efLkmh3k7NmzxVlfyeVXLesDAwMd//KrnuMIcnNz77777t27d0dERHz44Yf2OxEA10G2l4tsRw3QuMNRHD9+/J577jl//vzEiRM///xzWx3WOS6/6jaO4KWXXpo5c2bHjh23b99ep04dO50FgOsg2ytBtqO6aNzhEK5evRoUFJSamjpgwIAVK1a4u7vb6USFhYUnTpwozvrk5ORz586V3MHd3b1Dhw7FWX/PPffcfPPNdiqmWnQYR7Bx48Y+ffpYLJZNmzb16NHD5scH4GrI9hsi21EtNO4wXn5+/sMPP7x27dpOnTpt2rSpUaNGZfe5cOFC48aNPT09bX729PT04qx38Muvdh1HcO3ata5dux45cmT69OlRUVE2PDIA10S2VxHZjqqjcYfxnnnmmdjYWD8/vy1btrRs2bLcfYYPH56QkNChQ4fikO3Zs+ctt9xi82KuXbu2a9eunTt3pqSk7NixIzU1NTs7u+QOjRs37tq1a/369Zs2bfrQQw+NGDFCh4eKitlvHMG4ceO+/vrru+66a8uWLXr+iQA4K7K96sh2VBGNOwymDQirU6fOhg0bKrmE179//7Vr15ZaL2nVqpX2qg7t/7Zt29bm5ZW6/Lpt27bffvut5A5du3bdtm2b1Wq1+akrYfNxBAkJCY888oi3t3dycnKnTp1sUiQAV0a21wDZjhtTgHHi4+OtVqvVal22bNkNd87NzU1NTY2Li4uIiAgKCqpXr16pb+aGDRsGBQWFh4fHxMQkJSVlZWXZo+azZ8+uXr16yJAhLVq00K6rfvbZZ/Y4UeW+/fbbunXrishDDz2Unp5em0NduHChadOmIjJr1ixblQfAlZHtNUa2o3KsuMMwtR8Qdvbs2eLFkr179x49erTkVu1RpOLLrz169NAizIZ69OixdevWgICAlJQU2x65Kmw1jmDEiBFLly596KGHEhMTHXx6GgDHR7bXEtmOStC4wxjHjh3r1auXbQeElXoU6cCBA4WFhSV38PPzK876wMDAO+64o5aXQePj4x977LEmTZpcuHDBftMSKlH7cQRfffXV+PHjGzVqtGvXropuQgWAKiLbbYJsR0Vo3GEAfQaE5eXlHTp0qDjrd+7cee3atZI7NGjQoEOHDsVZf9ddd2kXKKulc+fOe/bsWbNmTf/+/W1XezXUZhzB8ePHAwICrl69+u9//3v06NH2KxKAKyDbbYhsR/kMvlUHricvLy84OFhEOnXqlJGRoeepz5w5k5CQEBUVFRISUvZpJ3d3d39//9DQ0KioqISEhHPnzlXlmG+++aaIjB071s61V6agoODZZ58VEYvFEhUVVcWvKiws7NOnj4gMHTrUntUBcAlku82R7SiLFXforSoDwvSRkZGRmppafBvl7t278/LySu5QlcuvR44cad++ff369c+fP2/s6+iqO45gxowZU6ZMueWWW3bv3m2P4WsAXArZbidkO/6L0f9y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qQEOcXFx2hJFuVvPnDlT3Ym/puAI4wiqh2xXSpHtZHsVkO0asl2HbDeicb90SdWrp0TU55+Xs//Bg6p+fSWi5s+3QW16cfoBYZWIiIgQkSlTphhdiAlkZmbWr1/fYrEcPXp037592rsqunfvfvHiRaNL09WLL74oIm+99ZbRhejN8HEE1UO2k+1ke9WQ7RqyXYdst4r+5ibWxSoAACAASURBVM6VzEzp0kUmTixna/v28sILIiKffKJzXTWWk5MzZMiQw4cPBwYGzp0712o14m/VOI8//riILFiwoLCw0OhaHF3dunWHDh2qlJo5c+b9999/+vTp+++/f926db6+vkaXpquUlBQRCQgIMLoQvfn5+W3YsGHo0KHp6en9+/efO3eu0RXZFNnuXMj2qiPbNWS7Htlug+a/uqsyISFKRE2fXuEBd+68frHVDFNyXWdAWCXat28vIiZYQXQAq1atEhGtAxg0aJCZHlW0He2X2alTp4wuxBimGTVDtpPtZHuVke2KbNcl2223fpCdLZs3l/O/PXtK77l3r4jInXdWeCh/f3F3l4ICOXjQZuXZzWuvvTZ//vwGDRokJCSUnEjqUh577DERWbhwodGFmECLFi3q1Knj4eFx3333LV26tE6dOkZXpLeTJ09eunTJx8dHu5rsgiwWy/Tp07VxBLNmzRo1alR2drbRRVWMbCfbyfYq6Nu3b48ePby8vMh2st2+2W6D5l9blan8fyVXZW66SYmo//3fyo6p7bNunQ3KsydXGxBWkX379olIkyZNcnJyjK7FoZ07d65169baj96QIUOMLscY3333nYgEBwcbXYjxHH3UDNlOtpPt1fHqq6+S7WS7snO2u9vsXwC+vjJhQjmfnz4t8+f/1ydubiIiRUWVHU27o87DQ0QkIUF8fKRLF2nQwDal2shPP/30zDPPiMisWbP69etndDlG6tixY7du3Xbs2LFmzZpHHnnE6HIcVHZ29rBhw44fP961a9dDhw6tWLEiNTW1c+fORtelN+0myK5duxpdiPH69u27cePGkJCQzZs39+rVa9WqVR07djS6qDLIdhdGtlfRuXPnfHx8Jk+eHBMTQ7YbXYjx7JvtNmj+q3sf5O23KxG1cGGFB8zOVlarElG7dyul1K23Xl/a8fNTISEqKkrFx6vUVGNnirnmgLBKvPfeeyLy2GOPGV2IgyoqKtKe9GrduvW5c+e0cQ1PPvmk0XUZ4NFHH5WKXw/ughx31AzZDrK9al5++eVdu3apP0bxkO1Qdst2Ixr3kSOViPrb3yo84ObNSkTVqaPy8lRurho/Xt11l/L0LH2J1tdXBQerKVPUvHlq926Vn2+DP0vVuPKAsIqcOXPGarV6e3uXfV8alFKRkZEi0rBhQy3cT5065enp6ebmdujQIaNL01vbtm1FZLfWukEppdS1a9eGDh0qIm5ubuHh4UaX8weyHWR7NZHtZHtJ9sh2Ixr3zz+//klF78167jklUvpN2vn5KjVVxcerqCgVEqKaNi2d9R4eyt9fhYWpmBiVmKjsNjw1Ozu7d+/eIhIYGHjNDLMRdPPAAw+IyNy5c40uxOF8+eWXIuLh4fHDDz8Ufzhu3DgRmTRpkoGF6e/KlSsWi8XLy8spX8NRG4WFhdo1GRF58MEHjS5HKUW24zqyvSIpKSkvvfRSqZeAku1G1+JYbJ7tRjTu164pX18lot59t5z9t2+/vgBTosUp34kTKiFBvfmmGj5ctW2rLJb/ynqLRbVrp4YPV//zP1dWrz558mRN/3j/hQFhlYiNjRWRgQMHGl2IY1m/fr2np6eIfPrppyU/379/v9Vq9fLycqn36v30008i0r17d6MLcVBavIhISkqK0bWQ7biObK/IlStXHn300f3795f8kGxHWTbMdiMad6XUkiXKYlEWi3rxRXXu3PUPs7PV3LnKx0eJqLFjq13G1asqOVnFxamICBUUpOrWLQ763fffLyKNGjUKCgqKiIiIjY1NSkrKzs6u9imUmjZtmog0aNBg586dNfhy53b58mUvLy93d/dzxf9NXd7evXsbN24sIq+88krZrSNGjHC1W2lnzZolIhMnTjS6EMelzYHeuHGj0YWQ7biObC9r7969lWwl21GWrbLdoMZdKRUXd/3l2FaratlSdeyo6tS5HscTJqjaX2rJz1e7dql589RLLy2bONHHx6fUU7leXl533XXX+PHjZ82a9eOPP2ZkZNzwkAwIu6EhQ4aIyL/+9S+jC3EIFy9e1O6XHTFiRLn3y+7YscNisdSrV+/SpUv6l2eICRMm8B1Sie3bt4uIxWJxiBusyXb8gWwvKTc3t3PnzlOmTKno55RsRyk2zHZbNO47dqjBg9Wzz5a/dc8eNXiwKveW/DNnVFSUuvde1aKFuvVW1aWLeuYZ9fPPNiipPGfOnElMTIyJiQkLC/P39y/78mo/P7+QkJCoqKj4+PjU1NSi/55s8OOPP3p5eYnIJ598YqcKnYD2no7evXsbXYjxsrKyevXqpV06zMzMrGi3/v37i8ibb76pZ20GCgwMFJGffvrJ6EIMtn79+uTk5Nzc3FKfL1++XET8K+qVdUa24w9keymXL19+5JFHjh49WtEOZLtr0iHbbdG4m9PVq1eTkpI++uijiRMndu/e3dvbu1TWN2nS5E9/+tPkyZPj4uKWLVvGgLCqyMzMrF+/vsViqSTOXEGp4Y+V7LlhwwYR8fHx+f3333Urzyj5+fne3t4Wi6Uqi6DOzd/fX0S2bt1a6vO3335bRF544QVDqnIOZLs9kO2ad9555+uvv67KnmS7a9Ih2123cS+loKDgyJEjCQkJUVFRISEhZV9wbbFYhg0b5hDXrx3bk08+KSJvv/220YUYqdTwx8oFBQWJyAcffKBDYcbatWuXiLRr187oQgyWlZXl7u7u7u5e9m7skSNHishXX31lRF3OiWy3FbJdKXXo0KHbb789IiKiKt8wZLur0SfbadwrdPr06ZUrV7799tuhoaHaq2tXr15tdFEmsGrVKhG54447jC7EMOUOf6zEihUrRKR58+ZlL645mblz54rI8OHDjS7EYL/88ouIdO7cueymDh06iMiOHTv0r8p1kO0148rZnpubW/xTefHixZCQkKqMMyLbXY0+2V76XkAUa9as2aBBg6ZNmxYfH//888+LyLffflt2t4yMjDlz5iQlJeleoIPq169f06ZN9+3bp/0T3NVs2LBh0qRJIjJr1qy+fftW5UsGDRrUrVu306dPz5s3z87VGWznzp0iEhAQYHQhBqvoxeCZmZmHDx/29PTULrbCTsj2mnHlbN+zZ0///v0XLVokIr6+vitWrGjRosUNv4psdzX6ZDuNe5Vo9ysvWbIkNze31KY5c+ZMmDBBG4QEEXF3d9cmYS1YsMDoWvS2b9++YcOG5eXlvfLKK88880wVv8pisUydOlVE3n333cLCQnsWaLCKQs3VVPRLbufOnUVFRf7+/trgf+iAbK86V872bt26rVu37uWXX54+fXrVv4psdzX6ZDuNe5V07NjxrrvuysjI+M9//lNq0+OPP+7m5rZy5corV64YUpsD0n4XLliwoKioyOha9HPp/PmH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9+zZo63Z7N27d/fu3Xl5ecVbg4ODExMTDSwPJa1aJSEh0qSJHD4sN91kdDVmcOTIkZCQkP379992220rVqy46667qvJVRUVFP//887x587755purV6+KiNVq7dWr15gxY0aNGlXLBR5AH2S7iZDt1UW2l4vG3RVlZWUtXbr0hx9+2Ldv38iRI//2t78ZXRGuKyqSwEBJSZEZM+TFF42uxjwuX748fPjwDRs21K9ff8GCBYMHD65k5z179sybNy8uLu7cuXPaJ/7+/mPGjBk7duytt96qS72AXZDtDotsrxmyvSwad8CBzJkjEyZI69ayf794eRldjank5eU99dRTc+fOdXNzmzlzZkRERKkd9u3bt2jRogULFhw6dEj75I477hg5cuTo0aPbt2+ve70AXAjZXmNkeyk07oCjyMmRDh3k1CmZP1+eeMLoakxIKfXee++98sorSqkuXbr8+uuvXl5eqamp69atW7x48aZNm7TdmjVrNnz48NDQ0HvvvdfYggG4ArK9lsj2kmjcAUfx7rsybZoEBMj27WK1Gl2Nac2ZM2fixIlKKe1eRu0eRxG56aabRowY8cQTT9x3331W/n4B6IVstwmyXWOyITiAs0pLS1u//rLV2v6f/yTZa2X8+PF5eXnPPvtscazfc889L7744iOPPOLp6WlsbQBcDdluK2S7hhV3wCFMnjw5JiYmLOx/5s59zehanMGPP/64aNEipVRUVJQzPZYEwFzIdtsi22ncAeMdO3bsjjvuyM/PT05O7tatm9HlAABsgGyHzXHZBjDetGnTcnNzw8LCSHYAcBpkO2yOFXfAYCkpKYGBgZ6engcOHGjJW7ABwCmQ7bAHVtwBg02ZMqWoqCgiIoJkBwCnQbbDHlhxB4y0evXqQYMGNWnS5PDhwzfxFmwAcApkO+yEFXfAMEVFRa+++qqIvPbaayQ7ADgHsh32w4o7YJivvvpq/PjxrVu33r9/vxdvwQYAp0C2w35o3AFj5OTk3H777SdPnvz3v/89evRoo8sBANgA2Q674lYZwBgffPDByZMnAwICHn/8caNrAQDYBtkOu2LFHTBAenp6u3bt0tPTf/jhh759+xpdDgDABsh22Bsr7oAB3nzzzfT09AEDBpDsAOA0yHbYGyvugN6OHz/esWNHXoINAM6EbIcOWHEH9MZLsAHA+ZDt0AEr7oCueAk2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",
      "text/plain": [
       "<IPython.core.display.Image object>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Looking for the most similar molecules\n",
    "test_idx = similar_idx[5]\n",
    "train_idx = nearest_idx[test_idx]\n",
    "\n",
    "train_similar = train_smiles[train_idx]\n",
    "test_similar = test_smiles[test_idx]\n",
    "\n",
    "from rdkit import Chem\n",
    "from rdkit.Chem import Draw\n",
    "\n",
    "def draw_molecules(train_smiles, test_smiles):\n",
    "    # Convert SMILES to RDKit molecule objects\n",
    "    train_mol = Chem.MolFromSmiles(train_smiles)\n",
    "    test_mol = Chem.MolFromSmiles(test_smiles)\n",
    "\n",
    "    # Check if the molecules were created successfully\n",
    "    if train_mol is None or test_mol is None:\n",
    "        print(\"One or both of the provided SMILES strings are invalid.\")\n",
    "        return\n",
    "\n",
    "    # Create a list of the molecule objects\n",
    "    mols = [train_mol, test_mol]\n",
    "    labels = ['train', 'test']\n",
    "\n",
    "    # Draw the molecules in a 1x2 grid\n",
    "    img = Draw.MolsToGridImage(mols, molsPerRow=2, subImgSize=(500, 500), legends=labels)\n",
    "\n",
    "    # Display the image\n",
    "    return img\n",
    "\n",
    "draw_molecules(train_similar, test_similar)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<rdkit.Chem.rdchem.Mol at 0x7f6eaf8ed850>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Chem.MolFromSmiles(train_similar)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<rdkit.Chem.rdchem.Mol at 0x7f6eaf8eee30>"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Chem.MolFromSmiles(test_similar)"
   ]
  },
  {
   "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
}
