{
 "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 rdkit import Chem\n",
    "from rdkit.Chem import Draw\n",
    "from rdkit.Chem.Draw import IPythonConsole\n",
    "from rdkit.Chem import AllChem, MACCSkeys"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "train = pd.read_csv('../../data/lo/drd2/train_1.csv')\n",
    "test = pd.read_csv('../../data/lo/drd2/test_1.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<IPython.core.display.Image object>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "smiles = test[test['cluster'] == 1]['smiles'].to_list()\n",
    "molecules = [Chem.MolFromSmiles(smiles) for smiles in smiles]\n",
    "img = Draw.MolsToGridImage(molecules, molsPerRow=5, subImgSize=(300, 300))\n",
    "img"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Check for nearest neighbors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../../code')\n",
    "\n",
    "from splits import get_nearest_mols"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "from rdkit import Chem, DataStructs\n",
    "\n",
    "lhs_mols = []\n",
    "for smiles in test['smiles']:\n",
    "    lhs_mols.append(Chem.MolFromSmiles(smiles))\n",
    "lhs_fps = [AllChem.GetMorganFingerprintAsBitVect(x, 2, 1024) for x in lhs_mols]\n",
    "\n",
    "rhs_mols = []\n",
    "for smiles in train['smiles']:\n",
    "    rhs_mols.append(Chem.MolFromSmiles(smiles))\n",
    "rhs_fps = [AllChem.GetMorganFingerprintAsBitVect(x, 2, 1024) for x in rhs_mols]\n",
    "\n",
    "nearest_dist = []\n",
    "nearest_idx = []\n",
    "for lhs in lhs_fps:\n",
    "    sims = DataStructs.BulkTanimotoSimilarity(lhs, rhs_fps)\n",
    "    nearest_dist.append(sims)\n",
    "    nearest_idx.append(np.argmax(sims))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "nearest_dist = np.stack(nearest_dist)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "max_cluster = test['cluster'].max()\n",
    "for i in range(1, max_cluster):\n",
    "    cluster_idx = np.where(test['cluster'] == i)[0]\n",
    "    distances = nearest_dist[cluster_idx]\n",
    "    is_near = distances > 0.40\n",
    "    each_has = True\n",
    "    only_one = True\n",
    "    if not np.all(is_near.sum(axis=1) == 1):  # each molecule in cluster have only one similar molecule in the train\n",
    "        each_has = False\n",
    "\n",
    "    if not len(np.unique(np.where(is_near)[1])) == 1:  # it is the same molecule for the whole cluster\n",
    "        only_one = True\n",
    "    if not each_has or not only_one:\n",
    "        print(i, each_has, only_one)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Check for conflicted clusters with the same fingerprint patterns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_per_cluster_diversity(data, is_morgan):\n",
    "    smiles = data['smiles']\n",
    "    mols = [Chem.MolFromSmiles(x) for x in smiles]\n",
    "    if is_morgan:\n",
    "        fps_vec = [AllChem.GetMorganFingerprintAsBitVect(x, 2, 1024) for x in mols]\n",
    "    else:\n",
    "        fps_vec = [Chem.MACCSkeys.GenMACCSKeys(x) for x in mols]\n",
    "\n",
    "    fps = [vec.ToList() for vec in fps_vec]\n",
    "    string_fps = []\n",
    "    for vec in fps:\n",
    "        sub_vec = [str(x) for x in vec]\n",
    "        string_fps.append(''.join(sub_vec))\n",
    "    string_fps = np.array(string_fps)\n",
    "\n",
    "    different_fps_per_cluster = []\n",
    "\n",
    "    for cluster_idx in data['cluster'].unique():\n",
    "        idx = data['cluster'] == cluster_idx\n",
    "        cluster_fps = set(string_fps[idx])\n",
    "        different_fps_per_cluster.append(len(cluster_fps))\n",
    "    return different_fps_per_cluster"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_1 = pd.read_csv('../../data/lo/drd2/train_1.csv')\n",
    "test_1 = pd.read_csv('../../data/lo/drd2/test_1.csv')\n",
    "\n",
    "train_2 = pd.read_csv('../../data/lo/drd2/train_2.csv')\n",
    "test_2 = pd.read_csv('../../data/lo/drd2/test_2.csv')\n",
    "\n",
    "train_3 = pd.read_csv('../../data/lo/drd2/train_3.csv')\n",
    "test_3 = pd.read_csv('../../data/lo/drd2/test_3.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 1.,  0.,  0.,  5.,  0.,  0., 60.,  0.,  0.,  9.]),\n",
       " array([3. , 3.3, 3.6, 3.9, 4.2, 4.5, 4.8, 5.1, 5.4, 5.7, 6. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 10,
     "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": [
    "plt.hist(calculate_per_cluster_diversity(test_1, True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 1.,  0.,  0.,  9.,  0.,  0., 52.,  0.,  0., 13.]),\n",
       " array([3. , 3.3, 3.6, 3.9, 4.2, 4.5, 4.8, 5.1, 5.4, 5.7, 6. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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9q1i12rZsmVRUlLS5TZs2LCEE58+Fi1aFCUlJTFv3rwTnjdY99Z/685aDea99eUvf/mo733KlCknfMxg3VfFrtVg3lcREX/961/jfe97X4wZMyaGDx8el156aWzYsOGEj3n88cfj8ssvj/Ly8jj//PNj2bJlvTrjgImPCRMmxKJFi6K1tTU2bNgQM2fOjOuuuy6effbZY57/xBNPxM033xxz5syJ3/72t3H99dfH9ddfH3/4wx8ST55esWsV8X+/CW/nzp2F21/+8peEE58enn766fjud78bU6dOPeF5g3lv/Ud31ypicO+tiy++uMv3/utf//q45w72fVXMWkUM3n31yiuvxJVXXhllZWXx6KOPxnPPPRff/va346yzzjruY7Zu3RqzZs2Kd7zjHbFx48aYN29efOhDH4o1a9b03qDZAHbWWWdl3//+949533ve855s1qxZXY5Nnz49++hHP5pitNPOidZq6dKlWS6XSzvQaWbPnj3Z5MmTs8ceeyz7n//5n+xTn/rUcc8d7HurmLUazHtr4cKF2WWXXdbt8wfzvip2rQbzvvr85z+fXXXVVUU95nOf+1x28cUXdzl20003ZXV1dT05WhcD5srHfzt06FCsWLEi9u3bd9xf6d7S0hK1tbVdjtXV1UVLS0uKEU8b3VmriIi9e/fGueeeG9XV1a96lWQgamhoiFmzZh21Z45lsO+tYtYqYnDvrS1btsT48ePjta99bcyePTu2bdt23HMH+74qZq0iBu+++ulPfxpXXHFFvPvd745x48bFG9/4xvje9753wsf0xd4aUPGxadOmGDFiRJSXl8fHPvaxeOihh+Kiiy465rltbW1H/cbVysrKaGtrSzFqnytmrS644IK4//774yc/+Uk88MADcfjw4XjLW94SL7/8cuKp+8aKFSvimWeeiebm5m6dP5j3VrFrNZj31vTp02PZsmWxevXqWLJkSWzdujXe+ta3xp49e455/mDeV8Wu1WDeV3/+859jyZIlMXny5FizZk18/OMfj09+8pPxgx/84LiPOd7e6uzsjH//+9+9M2ivXVPpA/l8PtuyZUu2YcOGbMGCBdnZZ5+dPfvss8c8t6ysLFu+fHmXY4sXL87GjRuXYtQ+V8xaHenAgQPZ6173uuy2227r5Sn73rZt27Jx48Zlv/vd7wrHXu2thMG6t05mrY40mPbWkV555ZWsoqLiuG9/DtZ9dSyvtlZHGkz7qqysLKupqelybO7cudmMGTOO+5jJkydnX//617scW7VqVRYR2b/+9a9emXNAXfkYOnRonH/++TFt2rRobm6Oyy67LO6+++5jnltVVRXt7e1djrW3t0dVVVWKUftcMWt1pLKysnjjG98YL7zwQi9P2fdaW1tj165dcfnll0dpaWmUlpbGunXr4p577onS0tI4dOjQUY8ZrHvrZNbqSINpbx1p1KhR8frXv/643/tg3VfH8mprdaTBtK/OOeeco65iX3jhhSd8m+p4e6uioiKGDx/eK3MOqPg40uHDhyOfzx/zvpqamli7dm2XY4899tgJP/cwkJ1orY506NCh2LRpU5xzzjm9PFXfu/rqq2PTpk2xcePGwu2KK66I2bNnx8aNG+OMM8446jGDdW+dzFodaTDtrSPt3bs3XnzxxeN+74N1Xx3Lq63VkQbTvrryyitj8+bNXY796U9/inPPPfe4j+mTvdUr11P6wIIFC7J169ZlW7duzX7/+99nCxYsyEpKSrJf/OIXWZZl2fvf//5swYIFhfN/85vfZKWlpdm3vvWt7Pnnn88WLlyYlZWVZZs2beqrbyGZYtfqK1/5SrZmzZrsxRdfzFpbW7P3vve92bBhw7r9Ns1Ac+RbCfbW8b3aWg3mvfXpT386e/zxx7OtW7dmv/nNb7La2trs7LPPznbt2pVlmX3134pdq8G8r5566qmstLQ0+9rXvpZt2bIle/DBB7Mzzzwze+CBBwrnLFiwIHv/+99f+PrPf/5zduaZZ2af/exns+effz5bvHhxdsYZZ2SrV6/utTlLey9r0tq1a1d84AMfiJ07d0Yul4upU6fGmjVr4p3vfGdERGzbti2GDPn/Cz1vectbYvny5XHbbbfFF77whZg8eXI8/PDDcckll/TVt5BMsWv1yiuvxIc//OFoa2uLs846K6ZNmxZPPPHEcT+gOtjYW91nb/2/l19+OW6++eb4xz/+EWPHjo2rrroq1q9fH2PHjo0I++q/FbtWg3lfvelNb4qHHnoompqa4vbbb49JkybFXXfdFbNnzy6cs3Pnzi5vw0yaNClWrVoV8+fPj7vvvjsmTJgQ3//+96Ourq7X5izJsizrtWcHADjCgP7MBwBw+hEfAEBS4gMASEp8AABJiQ8AICnxAQAkJT4AgKTEBwCQlPgAAJISHwBAUuIDAEhKfAAASf0vu3p+/rG1zEgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(calculate_per_cluster_diversity(test_2, True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 1.,  0.,  0.,  9.,  0.,  0., 58.,  0.,  0.,  7.]),\n",
       " array([3. , 3.3, 3.6, 3.9, 4.2, 4.5, 4.8, 5.1, 5.4, 5.7, 6. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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Ea+99lpcd911UV1dHQcPHuyOhwMAepFuiY9vf/vbcc8998Tdd98dV199dTzxxBNx+eWXx/e///3ueDgAoBfp8jecHj9+PBoaGqK2tjZ/bMCAAVFVVRX19fVnnN/W1hZtbW35n1taWiIiorW1tatHi4iIU23vdcv9dqfuWgvaszc4l964NyLsj1R64/7ojr3x2/vMsuyC53Z5fPzXf/1XnDx5MsrKytodLysri1/84hdnnF9XVxdf//rXzzheUVHR1aP1WrlHenoCLlX2Budjf3Au3bk3Dh8+HLlc7rzn9PhHbWtra2PZsmX5n0+dOhX//d//HaNGjYqioqIufazW1taoqKiIffv2RWlpaZfed19jrTrOWnWcteo4a1UY69Vx3bVWWZbF4cOHY9y4cRc8t8vj44orrojLLrssmpub2x1vbm6O8vLyM84vKSmJkpKSdseGDx/e1WO1U1paanN2kLXqOGvVcdaq46xVYaxXx3XHWl3oGY/f6vI3nA4aNCimT58eW7duzR87depUbN26NSorK7v64QCAXqZbXnZZtmxZ3HXXXTFjxoz4vd/7vXjkkUfi6NGjcffdd3fHwwEAvUi3xMftt98e//mf/xlf/epXo6mpKX73d383Nm/efMabUFMrKSmJFStWnPEyD2eyVh1nrTrOWnWctSqM9eq4S2GtirKOfCYGAKCL+L9dAICkxAcAkJT4AACSEh8AQFJ9Jj5Wr14d06ZNy39pSmVlZWzatOm8t9mwYUNMmTIlBg8eHB/5yEfiH//xHxNN27MKXau1a9dGUVFRu8vgwYMTTnzpWLlyZRQVFcWSJUvOe15/3Vvv15G16s9762tf+9oZv/uUKVPOe5v+uq8KXav+vK8iIn7961/HH//xH8eoUaNiyJAh8ZGPfCR27Nhx3tu88MILccMNN0RJSUlcddVVsXbt2m6dsc/Ex/jx42PlypXR0NAQO3bsiLlz58att94ar7/++lnPf+mll+LOO++MhQsXxr/+67/G/PnzY/78+fGzn/0s8eTpFbpWEf/3TXgHDhzIX/7jP/4j4cSXhldffTW+853vxLRp0857Xn/eW7/V0bWK6N9765prrmn3u//0pz8957n9fV8VslYR/XdfvfvuuzF79uwYOHBgbNq0Kd544434m7/5mxgxYsQ5b7N3796YN29e3HzzzbFz585YsmRJ/Omf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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(calculate_per_cluster_diversity(test_3, True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 1.,  0.,  4.,  0.,  0., 17.,  0., 48.,  0.,  5.]),\n",
       " array([2. , 2.4, 2.8, 3.2, 3.6, 4. , 4.4, 4.8, 5.2, 5.6, 6. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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FBs2bIhXvOIVERGxdOnSGDRoUMyePTvy+XzMmDEj7r333j4ZOABQmk77ez56WzGfEwagZ77ng5SSfM8HAMCpEB8AQFLiAwBISnwAAEmJDwAgKfEBACQlPgCApMQHAJCU+AAAkhIfAEBS4gMASEp8AABJiQ8AICnxAQAkJT4AgKTEBwCQlPgAAJISHwBAUuIDAEhKfAAASYkPACAp8QEAJCU+AICkxAcAkJT4AACSEh8AQFLiAwBISnwAAEmJDwAgKfEBACQlPgCApMQHAJCU+AAAkhIfAEBS4gMASEp8AABJiQ8AICnxAQAkJT4AgKTEBwCQlPgAAJISHwBAUuIDAEhKfAAASYkPACAp8QEAJCU+AICkxAcAkJT4AACSEh8AQFLiAwBISnwAAEmJDwAgKfEBACQlPgCApMQHAJCU+AAAkhIfAEBS4gMASEp8AABJiQ8AICnxAQAkVVR8NDU1xYte9KIYPnx4jB49OmbNmhXbt28vOObgwYPR0NAQo0aNimHDhsXs2bOjvb29VwcNAJSuouKjubk5GhoaYvPmzfHQQw/F4cOH45WvfGUcOHCg+5jbb789HnjggVizZk00NzfH7t2746abbur1gQMApam8mIPXr19f8PPKlStj9OjR0dLSEv/zP/8THR0dcf/998eqVati2rRpERGxYsWKuOSSS2Lz5s0xderU3hs5AFCSTus9Hx0dHRERMXLkyIiIaGlpicOHD8f06dO7j5k4cWKMHz8+Nm3adMxr5PP56OzsLNgAgIHrlOOjq6srFixYENdcc01cdtllERHR1tYWlZWVMWLEiIJja2pqoq2t7ZjXaWpqilwu173V1dWd6pAAgBJwyvHR0NAQv/3tb2P16tWnNYBFixZFR0dH99ba2npa1wMAzmxFvefj3+bNmxff//7346c//WmMGzeue39tbW0cOnQo9u7dW3D3o729PWpra495raqqqqiqqjqVYQAAJaioOx9ZlsW8efNi7dq18eMf/zjOO++8gscnT54cFRUVsXHjxu5927dvj127dkV9fX3vjBgAKGlF3floaGiIVatWxXe/+90YPnx49/s4crlcDB06NHK5XMydOzcaGxtj5MiRUV1dHfPnz4/6+nqfdAEAIqLI+Fi+fHlERLzsZS8r2L9ixYp4y1veEhERS5cujUGDBsXs2bMjn8/HjBkz4t577+2V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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(calculate_per_cluster_diversity(test_1, False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 1.,  0.,  8.,  0.,  0., 18.,  0., 41.,  0.,  7.]),\n",
       " array([2. , 2.4, 2.8, 3.2, 3.6, 4. , 4.4, 4.8, 5.2, 5.6, 6. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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bv+QseLiYhUVFYW+bm1t1b///W+lpKQoLi4uos8VCATk9XrV0NAgt9sd0cc+F8T6+qTYXyPrc75YXyPrc75ordGyLDU3NyszM/OM10Y8Pvr376+ePXuqqakp7HxTU5PS09NPud7lcsnlcoWd69evX6THCuN2u2P2Pyop9tcnxf4aWZ/zxfoaWZ/zRWONZ3rF42sRf8NpYmKixo0bp4qKitC51tZWVVRUyOfzRfrpAACAw0Tlxy5FRUWaM2eOLr/8cn3729/WypUr1dLSojvvvDMaTwcAABwkKvExa9Ys/fOf/9R9992nxsZGXXLJJdqyZcspb0I1zeVyadmyZaf8mCdWxPr6pNhfI+tzvlhfI+tzvnNhjXHW2fxODAAAQITwt10AAIBRxAcAADCK+AAAAEYRHwAAwKiYiY+SkhJdccUVSkpKUmpqqmbOnKm6uroz3m/9+vXKyspSr169NGbMGL322msGprWvM+tbs2aN4uLiwo5evXoZmti+0tJSZWdnhz74xufzafPmzae9j1P2T7K/PqftX1srVqxQXFycCgsLT3udk/bwm85mfU7bw/vvv/+UebOysk57H6ftn901Om0PJekf//iHfvCDHyglJUW9e/fWmDFjtHPnztPep7KyUpdddplcLpeGDx+uNWvWRHXGmImPqqoqFRQUaPv27dq6datOnDihadOmqaWlpcP7vPPOO7rllls0d+5cvf/++5o5c6ZmzpypDz74wODkZ6cz65P++wl2hw4dCh1///vfDU1s38CBA7VixQrV1NRo586dmjJlimbMmKEPP/yw3eudtH+S/fVJztq/b9qxY4eefPJJZWdnn/Y6p+3h1852fZLz9nDUqFFh87711lsdXuvU/bOzRslZe/jll19q4sSJSkhI0ObNm/XRRx/pd7/7nc4///wO71NfX6/p06fr6quvVm1trQoLC/WjH/1I5eXl0RvUilGHDx+2JFlVVVUdXvP973/fmj59eti58ePHWz/+8Y+jPV6Xnc36Vq9ebXk8HnNDRcH5559vPf300+3e5uT9+9rp1ufU/WtubrZGjBhhbd261brqqquse+65p8NrnbiHdtbntD1ctmyZNXbs2LO+3on7Z3eNTtvDxYsXW1deeaWt+9x7773WqFGjws7NmjXLys3NjeRoYWLmlY+2/H6/JCk5ObnDa6qrq5WTkxN2Ljc3V9XV1VGdLRLOZn2SdPToUQ0ePFher/eM/y/7XHLy5EmtW7dOLS0tHX4sv5P372zWJzlz/woKCjR9+vRT9qY9TtxDO+uTnLeHe/fuVWZmpoYOHarZs2frwIEDHV7rxP2T7K1RctYe/vnPf9bll1+um266Sampqbr00kv11FNPnfY+3bGPMRkfra2tKiws1MSJEzV69OgOr2tsbDzlU1fT0tLU2NgY7RG75GzXd9FFF+nZZ5/VK6+8ohdeeEGtra36zne+o88//9zgtPbs2bNHffv2lcvl0rx587RhwwaNHDmy3WuduH921ufE/Vu3bp127dqlkpKSs7reaXtod31O28Px48drzZo12rJli0pLS1VfX6/vfve7am5ubvd6p+2fZH+NTtvDTz/9VKWlpRoxYoTKy8s1f/58/eQnP9Fzzz3X4X062sdAIKD//Oc/0Rk0aq+pdKN58+ZZgwcPthoaGk57XUJCglVWVhZ2btWqVVZqamo0x+uys11fW8ePH7eGDRtmLV26NEqTdV0wGLT27t1r7dy501qyZInVv39/68MPP2z3Wifun531tXWu79+BAwes1NRU669//Wvo3Jl+LOGkPezM+to61/ewrS+//NJyu90d/mjQSfvXkTOtsa1zfQ8TEhIsn88Xdm7hwoXWhAkTOrzPiBEjrF/96ldh5zZt2mRJsr766quozBlzr3wsWLBAr776qrZt26aBAwee9tr09HQ1NTWFnWtqalJ6eno0R+wSO+trKyEhQZdeeqn27dsXpem6LjExUcOHD9e4ceNUUlKisWPH6tFHH233Wifun531tXWu719NTY0OHz6syy67TPHx8YqPj1dVVZUee+wxxcfH6+TJk6fcx0l72Jn1tXWu72Fb/fr104UXXtjhvE7av46caY1tnet7mJGRccqrqRdffPFpf7TU0T663W717t07KnPGTHxYlqUFCxZow4YNeuONNzRkyJAz3sfn86mioiLs3NatW0/7M/ju0pn1tXXy5Ent2bNHGRkZUZgwOlpbWxUMBtu9zUn715HTra+tc33/pk6dqj179qi2tjZ0XH755Zo9e7Zqa2vVs2fPU+7jpD3szPraOtf3sK2jR49q//79Hc7rpP3ryJnW2Na5vocTJ0485WMY/va3v2nw4MEd3qdb9jEqr6d0g/nz51sej8eqrKy0Dh06FDq++ZLRbbfdZi1ZsiT09dtvv23Fx8dbv/3tb62PP/7YWrZsmZWQkGDt2bOnO5ZwWp1Z3/Lly63y8nJr//79Vk1NjXXzzTdbvXr1OuuX+U1bsmSJVVVVZdXX11u7d++2lixZYsXFxVl/+ctfLMty9v5Zlv31OW3/2tP2xxJO38O2zrQ+p+3hT3/6U6uystKqr6+33n77bSsnJ8fq37+/dfjwYcuyYmP/7K7RaXv43nvvWfHx8daDDz5o7d2711q7dq3Vp08f64UXXghds2TJEuu2224Lff3pp59affr0sX7+859bH3/8sbVq1SqrZ8+e1pYtW6I2Z8zEh6R2j9WrV4euueqqq6w5c+aE3e/FF1+0LrzwQisxMdEaNWqUtWnTJrODn6XOrK+wsNAaNGiQlZiYaKWlpVnXXXedtWvXLvPDn6Uf/vCH1uDBg63ExERrwIAB1tSpU0PfmC3L2ftnWfbX57T9a0/bb85O38O2zrQ+p+3hrFmzrIyMDCsxMdH61re+Zc2aNcvat29f6PZY2D+7a3TaHlqWZW3cuNEaPXq05XK5rKysLOv3v/992O1z5syxrrrqqrBz27Ztsy655BIrMTHRGjp0aNj3lmiIsyzLit7rKgAAAOFi5j0fAADAGYgPAABgFPEBAACMIj4AAIBRxAcAADCK+AAAAEYRHwAAwCjiAwAAGEV8AAAAo4gPAABgFPEBAACMIj4AAIBR/w8QMXzhlDdaZQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(calculate_per_cluster_diversity(test_2, False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 1.,  0.,  4.,  0.,  0., 23.,  0., 41.,  0.,  6.]),\n",
       " array([2. , 2.4, 2.8, 3.2, 3.6, 4. , 4.4, 4.8, 5.2, 5.6, 6. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 15,
     "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": [
    "plt.hist(calculate_per_cluster_diversity(test_3, False))"
   ]
  },
  {
   "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
}
