{
 "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/kcnh2/train_1.csv')\n",
    "test = pd.read_csv('../../data/lo/kcnh2/test_1.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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GwcSCXC5EBEBdnaQlATHj0MxK15V8ff3T09P/+6779q1a8dy6KqOhYXFhQv/1969B1Vd538cfwGKooIZhmhumoUXyBTRVRfFStRMQaMUIy+DMnhNm42E3dqylt2RVl1DbaQLRY54C0xEFwQjdLzsKlOGwrZiaeuC7iahrCGCfH5/fI1t+lXeDn4Fn48/nDOc831/P99xOJzz+n4+70/Wxo0bvby8du3a5e/vv2jRoosXL/7gZbm5uQEBARMnTiwpKenZs+e6devmzp0bGxsbFxf3zTffBAYG5ufn5+Tk9O3b15arQL26Ou3eLUmdO6u0VB07qnt3B58iLy9PkrXwFsDP27dPkgYP1t69On9eAQF3XOmIa7N3715J1g1U4Cdda4qzevVqSR06dNi5c6fV6PegA7ux19QYHx8jmeRks3o1q+U++eQTq3trp06d9t7wbPLz58+/99571kIzq3nwJofsroGbzmqz7erqmp+fb9183rx5s2NKp6Yaydx9t0lLM5Lp0KFpdmu4aidPnvzVr34lqUWLFsuXL7+RUpcuXcrJyZkwYYI1tdC6k5mYmOigkQLXo6rKPPWUCQ01VVWmQXddsxpgrVixogHP0dSVl5dHR0db3VsfeOCB738qmDBhgvWhrmvXru++++769evr58sMGDAgg8btt5L6hjJvvGEkExHh4PqlpaWS3N3da27vJgDAVbrnHiOZ7GwjmXbtHLzTTG1trbUE1bFL4NH0XFso89///tfT01NSampqfaNfB4/ogw/MokWmosIkJ5v5883Klbd5Z5mvv/56+PDhklxdXZOSkq6vyOHDh2NjY63tlqz/Mqt58GeffebQweJmqG+z/cILL4SHh0saPXq0w6rX1Zl+/S7vi/vii6aoyGGVG62amhprK19JkydPPn/tYXFZWVl8fLy1IFHf9ZGx1kZt27atAYYMXK2qKjN1qtm50yxa1IChzKlTVR073u3q6nqDW1rAGLNr1y7rL7iTk9OUKVPOnDljjElOTm7fvv3ixYu3bdtm7Y4sqVevXhs3bryhTRjQAOobyoSHG8lc7ye7n7R27VpJY8aMcXBdoCn617+MZO64w6xdayTj8N+bgoICST4+Pg6uiybnmmfKHDhwICYm5ve//72ke++9t6E2JF6+3KxebYwx6ekmLq5BTtF4fP87YXR09NW3mPnmm29WrVpl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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"
   ]
  },
  {
   "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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_1 = pd.read_csv('../../data/lo/kcnh2/train_1.csv')\n",
    "test_1 = pd.read_csv('../../data/lo/kcnh2/test_1.csv')\n",
    "\n",
    "train_2 = pd.read_csv('../../data/lo/kcnh2/train_2.csv')\n",
    "test_2 = pd.read_csv('../../data/lo/kcnh2/test_2.csv')\n",
    "\n",
    "train_3 = pd.read_csv('../../data/lo/kcnh2/train_3.csv')\n",
    "test_3 = pd.read_csv('../../data/lo/kcnh2/test_3.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 2.,  0.,  0.,  0.,  0.,  1.,  0.,  0.,  0., 72.]),\n",
       " array([3. , 3.2, 3.4, 3.6, 3.8, 4. , 4.2, 4.4, 4.6, 4.8, 5. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 6,
     "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": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 1.,  0.,  0.,  1.,  0.,  0.,  2.,  0.,  0., 71.]),\n",
       " array([2. , 2.3, 2.6, 2.9, 3.2, 3.5, 3.8, 4.1, 4.4, 4.7, 5. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(calculate_per_cluster_diversity(test_2, True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 2.,  0.,  0.,  0.,  0.,  3.,  0.,  0.,  0., 70.]),\n",
       " array([3. , 3.2, 3.4, 3.6, 3.8, 4. , 4.2, 4.4, 4.6, 4.8, 5. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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D3/4Q2v+/Pnh+R988IEVHx9vPf3009Zf//pXa+HChVZCQoK1d+/e8JyKigorJSXFeuONN6yPPvrImjJlipWdnW395z//6fH9VVRUWImJidZrr71mHTlyJLwdO3bMsqyv7vZ+8MEHrZqaGqu+vt569913rauvvtoaPny41dra2uP7W7RokbV582br8OHDVm1trTVjxgwrKSnJ2r9/f3hOTzp/lhV9j6eNHz/emj59+jnjPe0cns/Z7ySw+zo828X6s9s6PNvF+rPjOjzbxXo8zS7r8Gc/+5m1detWq76+3vrggw+sgoIC65JLLrGOHj1qWVbPXYO2DR933323lZWVZSUmJlqDBg2yJk6cGP5P3bK++gErLi6OeMyrr75qXX755VZiYqJ1xRVXWG+99VbE/ra2NuvRRx+13G635XA4rIkTJ1p1dXUm2jlHtP1lZWVZks7ZFi5caFmWZX355ZfWTTfdZA0aNMhKSEiwsrKyrHvuucfy+XyGO/tKtP3NnTvXyszMtBITEy2322394Ac/sHbv3h1xzJ50/iyrYz+jBw4csCRFzDutp53D8zn7P3a7r8OzXaw/u63Ds12sPzuuw7O152fUTutw+vTp1pAhQ6zExETrm9/8pjV9+nTr0KFD4f09dQ3GWZZlxe46CgAAwNfrVfd8AACAno/wAQAAjCJ8AAAAowgfAADAKMIHAAAwivABAACMInwAAACjCB8AAMAowgcAADCK8AEAAIwifAAAAKMIHwAAwKj/A2/+yRnga5JZAAAAAElFTkSuQmCC",
      "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": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 1.,  0.,  1.,  0.,  0.,  4.,  0., 18.,  0., 51.]),\n",
       " array([1. , 1.4, 1.8, 2.2, 2.6, 3. , 3.4, 3.8, 4.2, 4.6, 5. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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rFmzoqGhISoqKqK8vDzuvffeqKmpOe13ugAA/V9B8bF79+748Ic/HLt27YpcLhcTJkyI559/Pt73vvdFRMTChQtjwIABUVdXFx0dHTFlypR45JFHemVwAKA4nfHv+ehpfs8HAMXE7/n4ryS/5wMAoDvEBwCQlPgAAJISHwBAUuIDAEhKfAAASYkPACAp8QEAJCU+AICkxAcAkJT4AACSEh8AQFLiAwBISnwAAEmJDwAgKfEBACQlPgCApMQHAJCU+AAAkhIfAEBS4gMASEp8AABJiQ8AICnxAQAkJT4AgKTEBwCQlPgAAJISHwBAUuIDAEhKfAAASYkPACAp8QEAJCU+AICkxAcAkJT4AACSEh8AQFLiAwBISnwAAEmJDwAgKfEBACQlPgCApMQHAJCU+AAAkhIfAEBS4gMASEp8AABJiQ8AICnxAQAkJT4AgKTEBwCQlPgAAJISHwBAUuIDAEhKfAAASYkPACAp8QEAJCU+AICkxAcAkFRB8TF//vx45zvfGUOHDo0RI0bE9OnTY+vWrZ2uOXDgQNTX18fw4cNjyJAhUVdXF62trT06NABQvAqKj8bGxqivr49169bFqlWr4tChQ/H+978/9u/fn7/m/vvvj6effjqWL18ejY2NsXPnzrjtttt6fHAAoDgNLOTilStXdvp4yZIlMWLEiGhubo7/+7//i7a2tnjiiSdi6dKlMXny5IiIWLx4cVx22WWxbt26uO6663pucgCgKJ3Raz7a2toiIqKioiIiIpqbm+PQoUNRW1ubv2b8+PExZsyYaGpqOuFjdHR0RHt7e6cDAOi/uh0fR44cidmzZ8e73/3uuPLKKyMioqWlJUpLS2PYsGGdrq2srIyWlpYTPs78+fMjl8vlj+rq6u6OBAAUgW7HR319fWzevDmWLVt2RgPMnTs32tra8seOHTvO6PEAgLNbQa/5OOqee+6JZ555JtauXRujR4/On6+qqoqDBw/Gnj17Oj370draGlVVVSd8rLKysigrK+vOGABAESromY8sy+Kee+6JFStWxAsvvBAXXnhhp9snTpwYgwYNitWrV+fPbd26NbZv3x41NTU9MzEAUNQKeuajvr4+li5dGj/72c9i6NCh+ddx5HK5OPfccyOXy8WsWbOioaEhKioqory8PO69996oqanxThcAICIKjI9HH300IiJuvPHGTucXL14c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5ztj6NChMWLEiJg+fXps3br1lPdbvnx5jB8/PgYPHhxvf/vb4+c//3mCaQvXnfUtWbLkuP0bPHhwookL8+ijj8aECRPyv7iopqYmnnvuuZPep1j27qhC11hM+3ciCxYsiJKSkpg9e/ZJryu2fTzqdNZXbHv4la985bh5x48ff9L79MX+9Zv42L9/f1x11VWxaNGi07p+27ZtMW3atLjpppti48aNMXv27PjYxz4Wzz//fC9P2n2FrvGorVu3xq5du/LHiBEjemnCM9PY2Bj19fWxbt26WLVqVRw6dCje//73x/79+7u8z29+85u48847Y9asWbFhw4aYPn16TJ8+PTZv3pxw8tPTnfVF/Pe3EP7v/v3lL39JNHFhRo8eHQsWLIjm5uZ4+eWXY/LkyXHrrbfGli1bTnh9Me3dUYWuMaJ49u9Y69evj8cffzwmTJhw0uuKcR8jTn99EcW3h1dccUWneX/96193eW2f7V/WD0VEtmLFipNe8/nPfz674oorOp2bMWNGNmXKlF6crOeczhp/9atfZRGR/etf/0oyU0/bvXt3FhFZY2Njl9d88IMfzKZNm9bp3KRJk7JPfvKTvT3eGTud9S1evDjL5XLphuph5513Xvb973//hLcV8979r5OtsVj3b+/evdkll1ySrVq1Krvhhhuy++67r8tri3EfC1lfse3hvHnzsquuuuq0r++r/es3z3wUqqmpKWprazudmzJlSjQ1NfXRRL3n6quvjpEjR8b73ve+ePHFF/t6nNPW1tYWEREVFRVdXlPM+3g664uI2LdvX4wdOzaqq6tP+a/ss8Xhw4dj2bJlsX///i7/rEIx713E6a0xojj3r76+PqZNm3bc/pxIMe5jIeuLKL49fPXVV2PUqFFx0UUXxV133RXbt2/v8tq+2r8+/6u2faWlpeW437haWVkZ7e3t8Z///CfOPffcPpqs54wcOTIee+yxuPbaa6OjoyO+//3vx4033hgvvfRSXHPNNX093kkdOXIkZs+eHe9+97vjyiuv7PK6rvbxbH1dy1Gnu75x48bFD37wg5gwYUK0tbXFt7/97bj++utjy5YtMXr06IQTn55NmzZFTU1NHDhwIIYMGRIrVqyIyy+//ITXFuveFbLGYtu/iIhly5bFK6+8EuvXrz+t64ttHwtdX7Ht4aRJk2LJkiUxbty42LVrVzzwwAPx3ve+NzZv3hxDhw497vq+2r83bHy8EYwbNy7GjRuX//j666+P119/PRYuXBg/+tGP+nCyU6uvr4/Nmzef9GeVxex011dTU9PpX9XXX399XHbZZfH444/H1772td4es2Djxo2LjRs3RltbW/z0pz+NmTNnRmNjY5ffnItRIWsstv3bsWNH3HfffbFq1aqz+kWV3dWd9RXbHk6dOjX/3xMmTIhJkybF2LFj48knn4xZs2b14WSdvWHjo6qqKlpbWzuda21tjfLy8n7xrEdX3vWud53139DvueeeeOaZZ2Lt2rWn/JdFV/tYVVXVmyOekULWd6xBgwbFO97xjnjttdd6abozU1paGhdffHFEREycODHWr18f3/nOd+Lxxx8/7tpi3LuIwtZ4rLN9/5qbm2P37t2dnhk9fPhwrF27Nr773e9GR0dHnHPOOZ3uU0z72J31Hets38NjDRs2LC699NIu5+2r/XvDvuajpqYmVq9e3encqlWrTvqz2/5g48aNMXLkyL4e44SyLIt77rknVqxYES+88EJceOGFp7xPMe1jd9Z3rMOHD8emTZvO2j081pEjR6Kjo+OEtxXT3p3MydZ4rLN9/26++ebYtGlTbNy4MX9ce+21cdddd8XGjRtP+I25mPaxO+s71tm+h8fat29fvP76613O22f716svZ01o79692YYNG7INGzZkEZE9+OCD2YYNG7K//OUvWZZl2Zw5c7IPfehD+ev/9Kc/ZW9605uyz33uc9kf/vCHbNGiRdk555yTrVy5sq+WcEqFrnHhwoXZU089lb366qvZpk2bsvvuuy8bMGBA9stf/rKvlnBSn/70p7NcLpetWbMm27VrV/7497//nb/mQx/6UDZnzpz8xy+++GI2cODA7Nvf/nb2hz/8IZs3b142aNCgbNOmTX2xhJPqzvoeeOCB7Pnnn89ef/31rLm5ObvjjjuywYMHZ1u2bOmLJZzUnDlzssbGxmzbtm3Z7373u2zOnDlZSUlJ9otf/CLLsuLeu6MKXWMx7V9Xjn03SH/Yx/91qvUV2x5+5jOfydasWZNt27Yte/HFF7Pa2trsLW95S7Z79+4sy86e/es38XH0baXHHjNnzsyyLMtmzpyZ3XDDDcfd5+qrr85KS0uziy66KFu8eHHyuQtR6Bq/8Y1vZG9729uywYMHZxUVFdmNN96YvfDCC30z/Gk40doiotO+3HDDDfn1HvXkk09ml156aVZaWppdccUV2bPPPpt28NPUnfXNnj07GzNmTFZaWppVVlZmH/jAB7JXXnkl/fCn4aMf/Wg2duzYrLS0NDv//POzm2++Of9NOcuKe++OKnSNxbR/XTn2m3N/2Mf/dar1FdsezpgxIxs5cmRWWlqavfWtb81mzJiRvfbaa/nbz5b9K8myLOvd51YAAP6/N+xrPgCAviE+AICkxAcAkJT4AACSEh8AQFLiAwBISnwAAEmJDwAgKfEBACQlPgCApMQHAJCU+AAAkvp/iiL8ZGpHBfIAAAAASUVORK5CYII=",
      "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": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 1.,  0.,  1.,  0.,  0.,  3.,  0., 19.,  0., 51.]),\n",
       " array([1. , 1.4, 1.8, 2.2, 2.6, 3. , 3.4, 3.8, 4.2, 4.6, 5. ]),\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_2, False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 1.,  0.,  0.,  0.,  0.,  5.,  0., 17.,  0., 52.]),\n",
       " array([1. , 1.4, 1.8, 2.2, 2.6, 3. , 3.4, 3.8, 4.2, 4.6, 5. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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FRUVR906OjrSDFykBQsWxNvf/vYYPnx4nHvuuTFjxozYvHnzSZ+3YsWKmDBhQgwdOjTe+ta3xs9//vME0xavN+tbunTpUfs3dOjQRBMX5/7774+JEycWfnBRQ0ND/OIXvzjhc8pl7w4rdo3ltH/HsnDhwqioqIg5c+ac8Lxy28fDTmV95baHX/3qV4+ad8KECSd8Tin2b8DEx969e+Pyyy+PxYsXn9L5W7ZsienTp8d73vOe2LhxY8yZMyc+/vGPx5NPPtnPk/ZesWs8bPPmzbFjx47C7dxzz+2nCU9Pa2trNDc3x/r162P16tVx4MCBeN/73hd79+497nN++9vfxs033xyzZ8+O559/PmbMmBEzZsyIF154IeHkp6Y364v4708h/N/9+8tf/pJo4uKMGTMmFi5cGO3t7fHss8/GlClT4sYbb4wXX3zxmOeX094dVuwaI8pn/460YcOGePDBB2PixIknPK8c9zHi1NcXUX57eOmll/aY9ze/+c1xzy3Z/mUDUERkK1euPOE5X/jCF7JLL720x7GZM2dmU6dO7cfJ+s6prPHXv/51FhHZv/71ryQz9bWdO3dmEZG1trYe95wPfvCD2fTp03scmzx5cvapT32qv8c7baeyviVLlmS5XC7dUH3sDW94Q/bQQw8d87Fy3rv/daI1luv+7d69O3vLW96SrV69Orv22muzO+6447jnluM+FrO+ctvD+fPnZ5dffvkpn1+q/Rswr3wUq62tLRobG3scmzp1arS1tZVoov5zxRVXxKhRo+K9731vPP3006Ue55R1dXVFRERNTc1xzynnfTyV9UVE7NmzJ8aNGxf19fUn/Vf2meLgwYOxfPny2Lt373F/rUI5713Eqa0xojz3r7m5OaZPn37U/hxLOe5jMeuLKL89fOmll2L06NFxwQUXxC233BJbt2497rml2r+S/1bbUuno6DjqJ67W1tZGd3d3/Oc//4mzzz67RJP1nVGjRsUDDzwQV111VeTz+XjooYfiuuuui2eeeSauvPLKUo93QocOHYo5c+bEO9/5zrjsssuOe97x9vFMfV/LYae6vvHjx8cjjzwSEydOjK6urrj77rvjmmuuiRdffDHGjBmTcOJTs2nTpmhoaIh9+/bFsGHDYuXKlXHJJZcc89xy3bti1lhu+xcRsXz58njuuediw4YNp3R+ue1jsesrtz2cPHlyLF26NMaPHx87duyIu+66K9797nfHCy+8EMOHDz/q/FLt32s2Pl4Lxo8fH+PHjy/cv+aaa+KVV16JRYsWxQ9/+MMSTnZyzc3N8cILL5zwa5Xl7FTX19DQ0ONf1ddcc01cfPHF8eCDD8bXv/71/h6zaOPHj4+NGzdGV1dX/OQnP4lZs2ZFa2vrcT85l6Ni1lhu+7dt27a44447YvXq1Wf0myp7qzfrK7c9nDZtWuG/J06cGJMnT45x48bFo48+GrNnzy7hZD29ZuOjrq4uOjs7exzr7OyM6urqAfGqx/G84x3vOOM/od92223xs5/9LNatW3fSf1kcbx/r6ur6c8TTUsz6jjRkyJB429veFi+//HI/TXd6Kisr48ILL4yIiEmTJsWGDRviO9/5Tjz44INHnVuOexdR3BqPdKbvX3t7e+zcubPHK6MHDx6MdevWxfe+973I5/Nx1lln9XhOOe1jb9Z3pDN9D480YsSIuOiii447b6n27zX7no+GhoZYs2ZNj2OrV68+4dduB4KNGzfGqFGjSj3GMWVZFrfddlusXLkynnrqqTj//PNP+pxy2sferO9IBw8ejE2bNp2xe3ikQ4cORT6fP+Zj5bR3J3KiNR7pTN+/66+/PjZt2hQbN24s3K666qq45ZZbYuPGjcf8xFxO+9ib9R3pTN/DI+3ZsydeeeWV485bsv3r17ezJrR79+7s+eefz55//vksIrJ77rkne/7557O//OUvWZZl2dy5c7MPf/jDhfP//Oc/Z6973euyz3/+89kf//jHbPHixdlZZ52VrVq1qlRLOKli17ho0aLssccey1566aVs06ZN2R133JENGjQo+9WvflWqJZzQZz7zmSyXy2Vr167NduzYUbj9+9//Lpzz4Q9/OJs7d27h/tNPP50NHjw4u/vuu7M//vGP2fz587MhQ4ZkmzZtKsUSTqg367vrrruyJ598MnvllVey9vb27EMf+lA2dOjQ7MUXXyzFEk5o7ty5WWtra7Zly5bs97//fTZ37tysoqIi++Uvf5llWXnv3WHFrrGc9u94jvxukIGwj//rZOsrtz387Gc/m61duzbbsmVL9vTTT2eNjY3ZG9/4xmznzp1Zlp05+zdg4uPwt5UeeZs1a1aWZVk2a9as7Nprrz3qOVdccUVWWVmZXXDBBdmSJUuSz12MYtf4zW9+M3vzm9+cDR06NKupqcmuu+667KmnnirN8KfgWGuLiB77cu211xbWe9ijjz6aXXTRRVllZWV26aWXZk888UTawU9Rb9Y3Z86cbOzYsVllZWVWW1ubvf/978+ee+659MOfgo997GPZuHHjssrKyuycc87Jrr/++sIn5Swr7707rNg1ltP+Hc+Rn5wHwj7+r5Otr9z2cObMmdmoUaOyysrK7E1velM2c+bM7OWXXy48fqbsX0WWZVn/vrYCAPD/vWbf8wEAlIb4AACSEh8AQFLiAwBISnwAAEmJDwAgKfEBACQlPgCApMQHAJCU+AAAkhIfAEBS4gMASOr/Abw05p4uLLeEAAAAAElFTkSuQmCC",
      "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
}
