{
 "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, DataStructs\n",
    "from rdkit.Chem import AllChem\n",
    "from rdkit.ML.Cluster import Butina\n",
    "\n",
    "from matplotlib_venn import venn3\n",
    "import networkx as nx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../../code')\n",
    "\n",
    "import min_vertex_k_cut"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "raw = pd.read_csv('../../data/raw/ADME_public_set_3521.csv')\n",
    "raw = raw.dropna(subset=['LOG SOLUBILITY PH 6.8 (ug/mL)'])\n",
    "solubility = np.array(raw['LOG SOLUBILITY PH 6.8 (ug/mL)'].to_list())\n",
    "solubility = solubility < 1.0\n",
    "smiles = raw['SMILES'].to_list()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>smiles</th>\n",
       "      <th>value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>CNc1cc(Nc2cccn(-c3ccccn3)c2=O)nn2c(C(=O)N[C@@H...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>CCOc1cc2nn(CCC(C)(C)O)cc2cc1NC(=O)c1cccc(C(F)F)n1</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>CC(C)(Oc1ccc(-c2cnc(N)c(-c3ccc(Cl)cc3)c2)cc1)C...</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>CC#CC(=O)N[C@H]1CCCN(c2c(F)cc(C(N)=O)c3[nH]c(C...</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>C=CC(=O)N1CCC[C@@H](n2nc(-c3ccc(Oc4ccccc4)cc3)...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2168</th>\n",
       "      <td>Cc1cc(C)cc(C(=O)NCCCNc2ncccn2)c1</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2169</th>\n",
       "      <td>CCc1noc(COc2c(C)ccnc2Cl)n1</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2170</th>\n",
       "      <td>CC(C)(C)Cc1nnc(-c2cnc3onc(C4CCCC4)c3c2)o1</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2171</th>\n",
       "      <td>Cc1nonc1C(=O)NCCc1c[nH]c2cccc(C3(O)CCOCC3)c12</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2172</th>\n",
       "      <td>CN1CC(=O)N(CCOc2ccccc2)C1=O</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>2173 rows × 2 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                 smiles  value\n",
       "0     CNc1cc(Nc2cccn(-c3ccccn3)c2=O)nn2c(C(=O)N[C@@H...   True\n",
       "1     CCOc1cc2nn(CCC(C)(C)O)cc2cc1NC(=O)c1cccc(C(F)F)n1   True\n",
       "2     CC(C)(Oc1ccc(-c2cnc(N)c(-c3ccc(Cl)cc3)c2)cc1)C...  False\n",
       "3     CC#CC(=O)N[C@H]1CCCN(c2c(F)cc(C(N)=O)c3[nH]c(C...  False\n",
       "4     C=CC(=O)N1CCC[C@@H](n2nc(-c3ccc(Oc4ccccc4)cc3)...   True\n",
       "...                                                 ...    ...\n",
       "2168                   Cc1cc(C)cc(C(=O)NCCCNc2ncccn2)c1  False\n",
       "2169                         CCc1noc(COc2c(C)ccnc2Cl)n1  False\n",
       "2170          CC(C)(C)Cc1nnc(-c2cnc3onc(C4CCCC4)c3c2)o1   True\n",
       "2171      Cc1nonc1C(=O)NCCc1c[nH]c2cccc(C3(O)CCOCC3)c12  False\n",
       "2172                        CN1CC(=O)N(CCOc2ccccc2)C1=O  False\n",
       "\n",
       "[2173 rows x 2 columns]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = pd.DataFrame({\n",
    "    'smiles': smiles,\n",
    "    'value': solubility\n",
    "})\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "smiles = data['smiles'].to_list()\n",
    "threshold = 0.4\n",
    "\n",
    "neighborhood_graph = min_vertex_k_cut.get_neighborhood_graph(smiles, threshold)\n",
    "main_component, small_components = min_vertex_k_cut.get_main_component(neighborhood_graph)\n",
    "\n",
    "old_nodes_to_new = dict(zip(main_component.nodes(), range(main_component.number_of_nodes())))\n",
    "new_nodes_to_old = {v: k for k, v in old_nodes_to_new.items()}\n",
    "main_component = nx.relabel_nodes(main_component, old_nodes_to_new)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.9 599 6.504173622704507\n",
      "0.8 581 6.209982788296041\n",
      "0.7 558 5.810035842293907\n",
      "0.6 507 4.986193293885601\n",
      "0.5 399 4.516290726817043\n",
      "0.4 203 4.354679802955665\n"
     ]
    }
   ],
   "source": [
    "for coarse_threhold in [0.90, 0.80, 0.70, 0.60, 0.50, 0.40]:\n",
    "    coarsed_main_component, _ = min_vertex_k_cut.coarse_graph(main_component, coarse_threhold)\n",
    "    node_degrees = list(dict(coarsed_main_component.degree()).values())\n",
    "    print(coarse_threhold, len(coarsed_main_component), np.mean(node_degrees))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "coarsed_main_component, node_to_cluster = min_vertex_k_cut.coarse_graph(main_component, 0.9)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total molecules: 599\n",
      "Min size of a partition: 119\n",
      "Welcome to the CBC MILP Solver \n",
      "Version: Trunk\n",
      "Build Date: Oct 24 2021 \n",
      "\n",
      "Starting solution of the Linear programming relaxation problem using Primal Simplex\n",
      "\n",
      "Coin0506I Presolve 10493 (-1797) rows, 1797 (0) columns and 23376 (-3594) elements\n",
      "Clp0014I Perturbing problem by 0.001% of 1.0288039 - largest nonzero change 9.9998062e-05 ( 0.0099998062%) - largest zero change 0\n",
      "Clp0000I Optimal - objective value 599\n",
      "Coin0511I After Postsolve, objective 599, infeasibilities - dual 0 (0), primal 0 (0)\n",
      "Clp0032I Optimal objective 599 - 2511 iterations time 0.092, Presolve 0.00, Idiot 0.02\n",
      "\n",
      "Starting MIP optimization\n",
      "Cgl0003I 0 fixed, 0 tightened bounds, 7862 strengthened rows, 0 substitutions\n",
      "Cgl0003I 0 fixed, 0 tightened bounds, 1909 strengthened rows, 0 substitutions\n",
      "Cgl0003I 0 fixed, 0 tightened bounds, 120 strengthened rows, 0 substitutions\n",
      "Cgl0004I processed model has 8247 rows, 1797 columns (1797 integer (1797 of which binary)) and 26529 elements\n",
      "Coin3009W Conflict graph built in 0.001 seconds, density: 0.181%\n",
      "Cgl0015I Clique Strengthening extended 0 cliques, 0 were dominated\n",
      "Cbc0045I Nauty: 11829 orbits (3 useful covering 6 variables), 1 generators, group size: 2 - sparse size 83930 - took 0.041241 seconds\n",
      "Cbc0038I Initial state - 1797 integers unsatisfied sum - 476\n",
      "Cbc0038I Pass   1: (1.10 seconds) suminf.  476.00000 (1797) obj. -599 iterations 342\n",
      "Cbc0038I Pass   2: (1.17 seconds) suminf.  444.04242 (1775) obj. -597.133 iterations 216\n",
      "Cbc0038I Pass   3: (1.21 seconds) suminf.  433.61214 (1723) obj. -596.797 iterations 121\n",
      "Cbc0038I Pass   4: (1.23 seconds) suminf.  423.21184 (1711) obj. -596.788 iterations 36\n",
      "Cbc0038I Pass   5: (1.36 seconds) suminf.  383.01892 (1657) obj. -592.635 iterations 527\n",
      "Cbc0038I Pass   6: (1.44 seconds) suminf.  378.06679 (1628) obj. -590.933 iterations 259\n",
      "Cbc0038I Pass   7: (1.57 seconds) suminf.  323.25852 (1376) obj. -586.799 iterations 512\n",
      "Cbc0038I Pass   8: (1.69 seconds) suminf.  261.40580 (1194) obj. -584.249 iterations 551\n",
      "Cbc0038I Pass   9: (1.78 seconds) suminf.  186.40905 (1068) obj. -583.234 iterations 371\n",
      "Cbc0038I Pass  10: (1.83 seconds) suminf.  174.22049 (1015) obj. -582.33 iterations 196\n",
      "Cbc0038I Pass  11: (1.86 seconds) suminf.  170.69730 (889) obj. -582.303 iterations 82\n",
      "Cbc0038I Pass  12: (2.03 seconds) suminf.   11.00000 (33) obj. -577 iterations 974\n",
      "Cbc0038I Solution found of -574\n",
      "Cbc0038I Before mini branch and bound, 0 integers at bound fixed and 0 continuous\n",
      "Cbc0038I Full problem 8247 rows 1797 columns, reduced to 8247 rows 1797 columns - 167 fixed gives 1558, 672 - ok now\n",
      "Cbc0038I Full problem 8247 rows 1797 columns, reduced to 1558 rows 672 columns\n",
      "Cbc0038I Mini branch and bound improved solution from -574 to -580 (2.26 seconds)\n",
      "Cbc0038I Round again with cutoff of -582.8\n",
      "Cbc0038I Pass  13: (2.27 seconds) suminf.  476.00000 (1797) obj. -599 iterations 0\n",
      "Cbc0038I Pass  14: (2.35 seconds) suminf.  428.17525 (1754) obj. -596.736 iterations 230\n",
      "Cbc0038I Pass  15: (2.42 seconds) suminf.  391.13081 (1652) obj. -595.869 iterations 255\n",
      "Cbc0038I Pass  16: (2.50 seconds) suminf.  297.94189 (1592) obj. -593.754 iterations 295\n",
      "Cbc0038I Pass  17: (2.58 seconds) suminf.  237.13646 (1426) obj. -592.864 iterations 334\n",
      "Cbc0038I Pass  18: (2.59 seconds) suminf.  237.13646 (1426) obj. -592.864 iterations 6\n",
      "Cbc0038I Pass  19: (2.65 seconds) suminf.  191.03176 (1395) obj. -589.478 iterations 239\n",
      "Cbc0038I Pass  20: (2.70 seconds) suminf.  185.01703 (1336) obj. -588.983 iterations 199\n",
      "Cbc0038I Pass  21: (2.82 seconds) suminf.   88.39002 (1281) obj. -586.872 iterations 534\n",
      "Cbc0038I Pass  22: (2.88 seconds) suminf.   81.29509 (913) obj. -586.705 iterations 288\n",
      "Cbc0038I Pass  23: (2.95 seconds) suminf.   49.40431 (779) obj. -585.412 iterations 267\n",
      "Cbc0038I Pass  24: (3.06 seconds) suminf.   33.70867 (1010) obj. -585.291 iterations 599\n",
      "Cbc0038I Pass  25: (3.12 seconds) suminf.   23.21342 (93) obj. -582.8 iterations 665\n",
      "Cbc0038I Pass  26: (3.17 seconds) suminf.   12.69245 (119) obj. -582.8 iterations 740\n",
      "Cbc0038I Pass  27: (3.21 seconds) suminf.   12.29288 (141) obj. -582.8 iterations 250\n",
      "Cbc0038I Pass  28: (3.28 seconds) suminf.    8.14639 (36) obj. -582.8 iterations 1111\n",
      "Cbc0038I Pass  29: (3.33 seconds) suminf.    5.24187 (27) obj. -582.8 iterations 729\n",
      "Cbc0038I Pass  30: (3.37 seconds) suminf.    0.60027 (3) obj. -582.8 iterations 853\n",
      "Cbc0038I Solution found of -583\n",
      "Cbc0038I Before mini branch and bound, 0 integers at bound fixed and 0 continuous\n",
      "Cbc0038I Full problem 8247 rows 1797 columns, reduced to 8247 rows 1797 columns - 254 fixed gives 3972, 976 - ok now\n",
      "Cbc0038I Full problem 8247 rows 1797 columns, reduced to 3972 rows 976 columns\n",
      "Cbc0038I Mini branch and bound improved solution from -583 to -589 (5.22 seconds)\n",
      "Cbc0038I Round again with cutoff of -591.8\n",
      "Cbc0038I Pass  31: (5.22 seconds) suminf.  476.00000 (1797) obj. -599 iterations 0\n",
      "Cbc0038I Pass  32: (5.34 seconds) suminf.  428.18635 (1752) obj. -596.091 iterations 419\n",
      "Cbc0038I Pass  33: (5.41 seconds) suminf.  391.05796 (1649) obj. -595.228 iterations 230\n",
      "Cbc0038I Pass  34: (5.44 seconds) suminf.  384.83725 (1637) obj. -595.06 iterations 87\n",
      "Cbc0038I Pass  35: (5.45 seconds) suminf.  379.64938 (1632) obj. -595.052 iterations 23\n",
      "Cbc0038I Pass  36: (5.48 seconds) suminf.  357.33209 (1607) obj. -594.668 iterations 77\n",
      "Cbc0038I Pass  37: (5.49 seconds) suminf.  357.33209 (1607) obj. -594.668 iterations 22\n",
      "Cbc0038I Pass  38: (5.64 seconds) suminf.  315.10372 (1549) obj. -591.8 iterations 604\n",
      "Cbc0038I Pass  39: (5.73 seconds) suminf.  306.15400 (1503) obj. -591.8 iterations 341\n",
      "Cbc0038I Pass  40: (5.75 seconds) suminf.  306.15400 (1503) obj. -591.8 iterations 48\n",
      "Cbc0038I Pass  41: (5.81 seconds) suminf.  298.20727 (1492) obj. -591.8 iterations 169\n",
      "Cbc0038I Pass  42: (5.84 seconds) suminf.  292.75156 (1543) obj. -591.8 iterations 104\n",
      "Cbc0038I Pass  43: (5.86 seconds) suminf.  292.75156 (1543) obj. -591.8 iterations 49\n",
      "Cbc0038I Pass  44: (5.90 seconds) suminf.  291.10026 (1552) obj. -591.8 iterations 120\n",
      "Cbc0038I Pass  45: (5.92 seconds) suminf.  291.10026 (1552) obj. -591.8 iterations 73\n",
      "Cbc0038I Pass  46: (5.98 seconds) suminf.  286.84813 (1542) obj. -591.8 iterations 198\n",
      "Cbc0038I Pass  47: (6.02 seconds) suminf.  286.80111 (1550) obj. -591.8 iterations 132\n",
      "Cbc0038I Pass  48: (6.05 seconds) suminf.  249.60874 (1528) obj. -591.8 iterations 115\n",
      "Cbc0038I Pass  49: (6.12 seconds) suminf.  247.62798 (1435) obj. -591.8 iterations 240\n",
      "Cbc0038I Pass  50: (6.15 seconds) suminf.  247.89872 (1429) obj. -591.8 iterations 78\n",
      "Cbc0038I Pass  51: (6.17 seconds) suminf.  242.64508 (1433) obj. -591.8 iterations 96\n",
      "Cbc0038I Pass  52: (6.25 seconds) suminf.  222.16270 (1409) obj. -591.8 iterations 300\n",
      "Cbc0038I Pass  53: (6.26 seconds) suminf.  222.16270 (1409) obj. -591.8 iterations 7\n",
      "Cbc0038I Pass  54: (6.30 seconds) suminf.  208.34425 (1401) obj. -591.8 iterations 141\n",
      "Cbc0038I Pass  55: (6.33 seconds) suminf.  206.01212 (1379) obj. -591.8 iterations 114\n",
      "Cbc0038I Pass  56: (6.41 seconds) suminf.  207.66819 (1392) obj. -591.8 iterations 273\n",
      "Cbc0038I Pass  57: (6.50 seconds) suminf.  146.65481 (1368) obj. -591.8 iterations 366\n",
      "Cbc0038I Pass  58: (6.59 seconds) suminf.  129.67547 (1352) obj. -591.8 iterations 384\n",
      "Cbc0038I Pass  59: (6.76 seconds) suminf.  122.02462 (848) obj. -591.8 iterations 846\n",
      "Cbc0038I Pass  60: (6.91 seconds) suminf.  119.73971 (880) obj. -591.8 iterations 716\n",
      "Cbc0038I No solution found this major pass\n",
      "Cbc0038I Before mini branch and bound, 0 integers at bound fixed and 0 continuous\n",
      "Cbc0038I Full problem 8247 rows 1797 columns, reduced to 8247 rows 1797 columns - 254 fixed gives 3972, 976 - ok now\n",
      "Cbc0038I Mini branch and bound did not improve solution (7.11 seconds)\n",
      "Cbc0038I After 7.11 seconds - Feasibility pump exiting with objective of -589 - took 6.03 seconds\n",
      "Cbc0012I Integer solution of -589 found by feasibility pump after 0 iterations and 0 nodes (7.11 seconds)\n",
      "Cbc0030I Thread 0 used 0 times,  waiting to start 0.10091782, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 1 used 0 times,  waiting to start 0.096705198, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 2 used 0 times,  waiting to start 0.091658831, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 3 used 0 times,  waiting to start 0.086484909, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 4 used 0 times,  waiting to start 0.081468344, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 5 used 0 times,  waiting to start 0.076312304, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 6 used 0 times,  waiting to start 0.071182013, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 7 used 0 times,  waiting to start 0.066244602, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 8 used 0 times,  waiting to start 0.06122756, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 9 used 0 times,  waiting to start 0.056023359, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 10 used 0 times,  waiting to start 0.051067114, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 11 used 0 times,  waiting to start 0.046200514, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 12 used 0 times,  waiting to start 0.041158915, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 13 used 0 times,  waiting to start 0.036133051, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 14 used 0 times,  waiting to start 0.031060934, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 15 used 0 times,  waiting to start 0.026322126, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 16 used 0 times,  waiting to start 0.021531582, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 17 used 0 times,  waiting to start 0.016790152, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 18 used 0 times,  waiting to start 0.012053967, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Thread 19 used 0 times,  waiting to start 0.0073268414, 0 cpu time, 0 locks, 0 locked, 0 waiting for locks\n",
      "Cbc0030I Main thread 0 waiting for threads,  1 locks, 1.9073486e-06 locked, 4.7683716e-07 waiting for locks\n",
      "Cbc0011I Exiting as integer gap of 10 less than 1e-10 or 2%\n",
      "Cbc0001I Search completed - best objective -589, took 0 iterations and 0 nodes (7.22 seconds)\n",
      "Cbc0035I Maximum depth 0, 0 variables fixed on reduced cost\n",
      "Total time (CPU seconds):       7.42   (Wallclock seconds):       7.54\n",
      "\n"
     ]
    }
   ],
   "source": [
    "model = min_vertex_k_cut.trisect_connected_graph(coarsed_main_component, part_min_frac=0.20, emphasis=1, max_mip_gap=0.02)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 10 119 120 350]\n"
     ]
    }
   ],
   "source": [
    "split = min_vertex_k_cut.process_trisect_results(model, coarsed_main_component, main_component, node_to_cluster)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "first_idx = []\n",
    "second_idx = []\n",
    "third_idx = []\n",
    "\n",
    "for S_idx, partition in enumerate(split):\n",
    "    G_idx = new_nodes_to_old[S_idx]\n",
    "    if partition == 0:\n",
    "        first_idx.append(G_idx)\n",
    "    if partition == 1:\n",
    "        second_idx.append(G_idx)\n",
    "    if partition == 2:\n",
    "        third_idx.append(G_idx)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "for component in small_components:\n",
    "    i = np.argmin([len(first_idx), len(second_idx), len(third_idx)])\n",
    "    if i == 0:\n",
    "        first_idx.extend(component)\n",
    "    if i == 1:\n",
    "        second_idx.extend(component)\n",
    "    if i == 2:\n",
    "        third_idx.extend(component)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[721, 721, 721]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[len(first_idx), len(second_idx), len(third_idx)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "part_first = data.iloc[first_idx]\n",
    "part_second = data.iloc[second_idx]\n",
    "part_third = data.iloc[third_idx]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib_venn._common.VennDiagram at 0x7f7c021b1540>"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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cnOvvTiFVveCoSA6PZ1w9bng6nehvb8dVzxXot57YDFZkJWUhdzkXDiSHXCkOJCdlM01AQzA7xenrqGXyyV6EqL9dMLQhT8399qpLCuL05hijWFApsFBMb23v19M7R36s8cjeheCQREkQiFxoTeZxEe7XczyT0kRH4dedjuPGBrG6/ei39c/4uXxeRAMBa++AHGHP/RKsiUh2ZY84sXH/+h6oZDoQRjtNOb1XjuFBYPi1DR0CrNYxHP/Q6eu609lCXy4RAqGASIiIoNj3x4REZHBMQwQEREZHMMAERGRwTEMEBERGRzDABERkcExDBARERkcwwAREZHBMQwo7g9/+ANMJhNWrlwpuxTSkXfffRcmk2nYa8qUKSgvL8fHH38suzzSkfr6emzZsgUlJSWw2+1IT0/HmjVr8Prrr8Pj8cguj77FdWoVV1FRgeLiYhw5cgR1dXWYNWuW7JJIR/71X/8VM2bMQCgUQmtrK959911897vfxY4dO3D//ffLLo80bufOnXjssceQmJiIH/3oR1iwYAEGBwexf/9+/PKXv8Tp06fx9ttvyy6TwDCgtIaGBhw8eBAfffQRtmzZgoqKCvz2t7+VXRbpyL333otly5Zd/fvTTz+NqVOn4sMPP2QYoElpaGjAE088gaKiIuzZswf5+flX33v++edRV1eHnTt3SqyQrsdhAoVVVFQgKysL9913Hx599FFUVFTILol0LjMzE0lJSbBycyuapN/97ndwu93405/+NCwIDJk1axZ+8YtfSKiMRsMwoLCKigo8/PDDSEhIwPe//33U1tbi6NGjsssiHenu7kZ7eztcLhdOnz6N5557Dm63Gz/84Q9ll0Yat2PHDpSUlGD16tWyS6EwMP4r6vjx46ipqcGbb74JAFi7di0KCwtRUVGB5cuXS66O9GLjxo3D/p6YmIh33nkHd999t6SKSA96enpw+fJlbN68WXYpFCaGAUVVVFRg6tSpKC8vBwCYTCY8/vjjeP/99/H73/8eFotFcoWkB2+99RZmz54NAGhtbcX777+PZ555BmlpaXj44YclV0da1dPTAwBIS0uTXAmFi8MECgoEAti2bRvKy8vR0NCAuro61NXVYeXKlWhtbcXnn38uu0TSiRUrVmDjxo3YuHEjfvCDH2Dnzp0oKyvDz372MwwODsoujzQqPT0dANDb2yu5EgoXw4CC9uzZg+bmZmzbtg2lpaVXX9/73vcAgBMJKWbMZjPKy8vR3NyM2tpa2eWQRqWnp6OgoABVVVWyS6EwcZhAQRUVFZgyZQreeuutEe999NFH+Otf/4o//vGPSEpKklAd6Z3f7wcAuN1uyZWQlt1///14++238Y9//AOrVq2SXQ6Ng2FAMR6PBx999BEee+wxPProoyPeLygowIcffojt27fj8ccfl1Ah6ZnP58OuXbuQkJCAefPmyS6HNOxXv/oVKioq8Mwzz2DPnj2YOnXqsPfr6+vx97//nY8XKoJhQDHbt29Hb28vHnzwwVHfv/322+FwOFBRUcEwQJP28ccfo6amBgDQ1taGDz74ALW1tfj1r399ddyXKBIzZ87EBx98gMcffxzz5s0btgLhwYMH8Ze//AU//vGPZZdJ3zKFQqGQ7CLomgcffBC7d+9GR0cHkpOTR/2cJ598EhUVFWhubkZOTk6cKyQ9ePfdd/Hkk08O+292ux1z587Fli1bsGXLFphMJknVkZ7U1tbitddew+7du+F0OpGYmIiFCxfiiSeewE9+8hMkJibKLpHAMEBERGR4fJqAiIjI4BgGiIiIDI5hgIiIyOAYBoiIiAyOYYCIiMjgGAaIiIgMjmGAiIjI4BgGiIiIDI5hgIiIyOAYBoiIiAyOYYCIiMjgGAaIiIgMjmGAiIjI4P4/6DJ7jukMCqQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "venn3([\n",
    "    set(part_first['smiles'].tolist()),\n",
    "    set(part_second['smiles'].tolist()),\n",
    "    set(part_third['smiles'].tolist()),\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_1 = pd.concat([part_first, part_second])\n",
    "test_1 = part_third.copy()\n",
    "\n",
    "train_2 = pd.concat([part_first, part_third])\n",
    "test_2 = part_second.copy()\n",
    "\n",
    "train_3 = pd.concat([part_second, part_third])\n",
    "test_3 = part_first.copy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "min_vertex_k_cut.test_split(train_1['smiles'], test_1['smiles'], threshold=0.4)\n",
    "min_vertex_k_cut.test_split(train_2['smiles'], test_2['smiles'], threshold=0.4)\n",
    "min_vertex_k_cut.test_split(train_3['smiles'], test_3['smiles'], threshold=0.4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib_venn._common.VennDiagram at 0x7f7c0148e890>"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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cnOvvTiFVveCoSA6PZ1w9bng6nehvb8dVzxXot57YDFZkJWUhdzkXDiSHXCkOJCdlM01AQzA7xenrqGXyyV6EqL9dMLQhT8399qpLCuL05hijWFApsFBMb23v19M7R36s8cjeheCQREkQiFxoTeZxEe7XczyT0kRH4dedjuPGBrG6/ei39c/4uXxeRAMBa++AHGHP/RKsiUh2ZY84sXH/+h6oZDoQRjtNOb1XjuFBYPi1DR0CrNYxHP/Q6eu609lCXy4RAqGASIiIoNj3x4REZHBMQwQEREZHMMAERGRwTEMEBERGRzDABERkcExDBARERkcwwAREZHBMQwo7g9/+ANMJhNWrlwpuxTSkXfffRcmk2nYa8qUKSgvL8fHH38suzzSkfr6emzZsgUlJSWw2+1IT0/HmjVr8Prrr8Pj8cguj77FdWoVV1FRgeLiYhw5cgR1dXWYNWuW7JJIR/71X/8VM2bMQCgUQmtrK959911897vfxY4dO3D//ffLLo80bufOnXjssceQmJiIH/3oR1iwYAEGBwexf/9+/PKXv8Tp06fx9ttvyy6TwDCgtIaGBhw8eBAfffQRtmzZgoqKCvz2t7+VXRbpyL333otly5Zd/fvTTz+NqVOn4sMPP2QYoElpaGjAE088gaKiIuzZswf5+flX33v++edRV1eHnTt3SqyQrsdhAoVVVFQgKysL9913Hx599FFUVFTILol0LjMzE0lJSbBycyuapN/97ndwu93405/+NCwIDJk1axZ+8YtfSKiMRsMwoLCKigo8/PDDSEhIwPe//33U1tbi6NGjsssiHenu7kZ7eztcLhdOnz6N5557Dm63Gz/84Q9ll0Yat2PHDpSUlGD16tWyS6EwMP4r6vjx46ipqcGbb74JAFi7di0KCwtRUVGB5cuXS66O9GLjxo3D/p6YmIh33nkHd999t6SKSA96enpw+fJlbN68WXYpFCaGAUVVVFRg6tSpKC8vBwCYTCY8/vjjeP/99/H73/8eFotFcoWkB2+99RZmz54NAGhtbcX777+PZ555BmlpaXj44YclV0da1dPTAwBIS0uTXAmFi8MECgoEAti2bRvKy8vR0NCAuro61NXVYeXKlWhtbcXnn38uu0TSiRUrVmDjxo3YuHEjfvCDH2Dnzp0oKyvDz372MwwODsoujzQqPT0dANDb2yu5EgoXw4CC9uzZg+bmZmzbtg2lpaVXX9/73vcAgBMJKWbMZjPKy8vR3NyM2tpa2eWQRqWnp6OgoABVVVWyS6EwcZhAQRUVFZgyZQreeuutEe999NFH+Otf/4o//vGPSEpKklAd6Z3f7wcAuN1uyZWQlt1///14++238Y9//AOrVq2SXQ6Ng2FAMR6PBx999BEee+wxPProoyPeLygowIcffojt27fj8ccfl1Ah6ZnP58OuXbuQkJCAefPmyS6HNOxXv/oVKioq8Mwzz2DPnj2YOnXqsPfr6+vx97//nY8XKoJhQDHbt29Hb28vHnzwwVHfv/322+FwOFBRUcEwQJP28ccfo6amBgDQ1taGDz74ALW1tfj1r399ddyXKBIzZ87EBx98gMcffxzz5s0btgLhwYMH8Ze//AU//vGPZZdJ3zKFQqGQ7CLomgcffBC7d+9GR0cHkpOTR/2cJ598EhUVFWhubkZOTk6cKyQ9ePfdd/Hkk08O+292ux1z587Fli1bsGXLFphMJknVkZ7U1tbitddew+7du+F0OpGYmIiFCxfiiSeewE9+8hMkJibKLpHAMEBERGR4fJqAiIjI4BgGiIiIDI5hgIiIyOAYBoiIiAyOYYCIiMjgGAaIiIgMjmGAiIjI4BgGiIiIDI5hgIiIyOAYBoiIiAyOYYCIiMjgGAaIiIgMjmGAiIjI4P4/6DJ7jukMCqQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "venn3([\n",
    "    set(test_1['smiles'].tolist()),\n",
    "    set(test_2['smiles'].tolist()),\n",
    "    set(test_3['smiles'].tolist()),\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib_venn._common.VennDiagram at 0x7f7c014b1cf0>"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "venn3([\n",
    "    set(train_1['smiles'].tolist()),\n",
    "    set(train_2['smiles'].tolist()),\n",
    "    set(train_3['smiles'].tolist()),\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_1.to_csv('../../data/hi/sol/train_1.csv')\n",
    "train_2.to_csv('../../data/hi/sol/train_2.csv')\n",
    "train_3.to_csv('../../data/hi/sol/train_3.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_1.to_csv('../../data/hi/sol/test_1.csv')\n",
    "test_2.to_csv('../../data/hi/sol/test_2.csv')\n",
    "test_3.to_csv('../../data/hi/sol/test_3.csv')"
   ]
  },
  {
   "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.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
