{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv ('all_results/all_results_bisect4.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "df['av'] = (df['degree'] + df['cluster'] + df['orbit'])/3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import yaml\n",
    "constr = 'maxDegree'\n",
    "master_constrs = yaml.load(open(f'config/constraints/master_{constr}.yaml', 'r'), Loader=yaml.FullLoader)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[2.0, 2.78, 3.56, 4.33, 5.11, 5.89, 6.67, 7.44, 8.22, 9.0]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "master_constrs['enzymes']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "     dataset method method_param  degree  cluster  orbit     av  constr_val\n",
      "426  enzymes   poly          0|1   0.265    0.802  0.018  0.362       1.000\n",
      "434  enzymes   poly        0.1|1   0.265    0.802  0.018  0.362       1.000\n",
      "442  enzymes  fixed            1   0.265    0.802  0.018  0.362       1.000\n",
      "448  enzymes   none            0   0.158    0.217  0.037  0.137       0.402\n"
     ]
    }
   ],
   "source": [
    "print (df.loc[(df['dataset'] == 'enzymes') & (df['constraint'] == constr) & (df['param'] == 5.11)][['dataset', 'method', 'method_param', 'degree', 'cluster', 'orbit', 'av', 'constr_val']].round(3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "             dataset method method_param  param  degree  cluster  orbit  \\\n",
      "99   community_small   poly          0|1    5.0   0.075    0.431  0.097   \n",
      "108  community_small   poly          0|5    5.0   0.190    0.281  0.026   \n",
      "122  community_small   poly        0.1|5    5.0   0.172    0.217  0.020   \n",
      "137  community_small   none            0    5.0   0.350    0.203  0.051   \n",
      "\n",
      "        av  constr_val  \n",
      "99   0.201        1.00  \n",
      "108  0.166        0.65  \n",
      "122  0.136        0.80  \n",
      "137  0.201        0.40  \n",
      "       dataset method method_param  param  degree  cluster  orbit     av  \\\n",
      "233  ego_small   poly          0|1    3.0   0.116    0.155  0.001  0.091   \n",
      "248  ego_small   poly        0.1|1    3.0   0.120    0.137  0.001  0.086   \n",
      "256  ego_small   poly        0.1|5    3.0   0.116    0.169  0.001  0.095   \n",
      "270  ego_small   none            0    3.0   0.131    0.238  0.018  0.129   \n",
      "\n",
      "     constr_val  \n",
      "233       0.650  \n",
      "248       0.650  \n",
      "256       0.675  \n",
      "270       0.325  \n",
      "Empty DataFrame\n",
      "Columns: [dataset, method, method_param, param, degree, cluster, orbit, av, constr_val]\n",
      "Index: []\n",
      "    dataset method method_param  param  degree  cluster  orbit     av  \\\n",
      "335    grid   poly          0|1    4.0   1.788    0.000  0.975  0.921   \n",
      "336    grid   poly          0|5    4.0   1.777    0.000  0.934  0.904   \n",
      "337    grid   poly        0.1|1    4.0   1.811    0.000  0.976  0.929   \n",
      "338    grid   poly        0.1|5    4.0   1.755    0.000  0.972  0.909   \n",
      "339    grid  fixed            1    4.0   1.759    0.000  0.975  0.911   \n",
      "340    grid   none            0    4.0   0.154    0.011  0.050  0.072   \n",
      "\n",
      "     constr_val  \n",
      "335         1.0  \n",
      "336         1.0  \n",
      "337         1.0  \n",
      "338         1.0  \n",
      "339         1.0  \n",
      "340         0.0  \n"
     ]
    }
   ],
   "source": [
    "for d, p in [(k, min(v)) for k, v in master_constrs.items()]:\n",
    "    print (df.loc[(df['dataset'] == d) & (df['constraint'] == constr) & (df['param'] == p)][['dataset', 'method', 'method_param', 'param', 'degree', 'cluster', 'orbit', 'av', 'constr_val']].round(3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "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>dataset</th>\n",
       "      <th>constraint</th>\n",
       "      <th>param</th>\n",
       "      <th>method</th>\n",
       "      <th>method_param</th>\n",
       "      <th>degree</th>\n",
       "      <th>cluster</th>\n",
       "      <th>orbit</th>\n",
       "      <th>spectral</th>\n",
       "      <th>constr_val</th>\n",
       "      <th>av</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>383</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>18.67</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|1</td>\n",
       "      <td>0.056174</td>\n",
       "      <td>0.298395</td>\n",
       "      <td>0.027567</td>\n",
       "      <td>0.062189</td>\n",
       "      <td>0.965812</td>\n",
       "      <td>0.127379</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>384</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>37.33</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|1</td>\n",
       "      <td>0.189586</td>\n",
       "      <td>0.425561</td>\n",
       "      <td>0.012198</td>\n",
       "      <td>0.022927</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.209115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>385</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>56.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|1</td>\n",
       "      <td>0.256763</td>\n",
       "      <td>0.504752</td>\n",
       "      <td>0.023565</td>\n",
       "      <td>0.019415</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.261693</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>386</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>74.67</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|1</td>\n",
       "      <td>0.260419</td>\n",
       "      <td>0.463694</td>\n",
       "      <td>0.025720</td>\n",
       "      <td>0.019565</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.249944</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>387</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>93.33</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|1</td>\n",
       "      <td>0.251587</td>\n",
       "      <td>0.485192</td>\n",
       "      <td>0.021985</td>\n",
       "      <td>0.019563</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.252921</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>388</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>168.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|1</td>\n",
       "      <td>0.261018</td>\n",
       "      <td>0.469308</td>\n",
       "      <td>0.024954</td>\n",
       "      <td>0.019667</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.251760</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>389</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>18.67</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|5</td>\n",
       "      <td>0.056174</td>\n",
       "      <td>0.298395</td>\n",
       "      <td>0.027567</td>\n",
       "      <td>0.062189</td>\n",
       "      <td>0.965812</td>\n",
       "      <td>0.127379</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>390</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>37.33</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|5</td>\n",
       "      <td>0.189586</td>\n",
       "      <td>0.425561</td>\n",
       "      <td>0.012198</td>\n",
       "      <td>0.022927</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.209115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>391</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>56.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|5</td>\n",
       "      <td>0.256763</td>\n",
       "      <td>0.504752</td>\n",
       "      <td>0.023565</td>\n",
       "      <td>0.019415</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.261693</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>392</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>93.33</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|5</td>\n",
       "      <td>0.251587</td>\n",
       "      <td>0.485192</td>\n",
       "      <td>0.021985</td>\n",
       "      <td>0.019563</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.252921</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>393</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>112.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|5</td>\n",
       "      <td>0.256999</td>\n",
       "      <td>0.453208</td>\n",
       "      <td>0.024429</td>\n",
       "      <td>0.019706</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.244879</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>394</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>149.33</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|5</td>\n",
       "      <td>0.267932</td>\n",
       "      <td>0.501595</td>\n",
       "      <td>0.025422</td>\n",
       "      <td>0.019711</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.264983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>395</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>168.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|5</td>\n",
       "      <td>0.261018</td>\n",
       "      <td>0.469308</td>\n",
       "      <td>0.024954</td>\n",
       "      <td>0.019667</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.251760</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>396</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>37.33</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|1</td>\n",
       "      <td>0.189586</td>\n",
       "      <td>0.425561</td>\n",
       "      <td>0.012198</td>\n",
       "      <td>0.022927</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.209115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>397</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>56.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|1</td>\n",
       "      <td>0.256763</td>\n",
       "      <td>0.504752</td>\n",
       "      <td>0.023565</td>\n",
       "      <td>0.019415</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.261693</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>398</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>74.67</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|1</td>\n",
       "      <td>0.260419</td>\n",
       "      <td>0.463694</td>\n",
       "      <td>0.025720</td>\n",
       "      <td>0.019565</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.249944</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>399</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>93.33</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|1</td>\n",
       "      <td>0.251587</td>\n",
       "      <td>0.485192</td>\n",
       "      <td>0.021985</td>\n",
       "      <td>0.019563</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.252921</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>400</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>112.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|1</td>\n",
       "      <td>0.256999</td>\n",
       "      <td>0.453208</td>\n",
       "      <td>0.024429</td>\n",
       "      <td>0.019706</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.244879</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>401</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>149.33</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|1</td>\n",
       "      <td>0.267932</td>\n",
       "      <td>0.501595</td>\n",
       "      <td>0.025422</td>\n",
       "      <td>0.019711</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.264983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>402</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>168.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|1</td>\n",
       "      <td>0.261018</td>\n",
       "      <td>0.469308</td>\n",
       "      <td>0.024954</td>\n",
       "      <td>0.019667</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.251760</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>403</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>18.67</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>0.056174</td>\n",
       "      <td>0.298395</td>\n",
       "      <td>0.027567</td>\n",
       "      <td>0.062189</td>\n",
       "      <td>0.965812</td>\n",
       "      <td>0.127379</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>404</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>37.33</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>0.189586</td>\n",
       "      <td>0.425561</td>\n",
       "      <td>0.012198</td>\n",
       "      <td>0.022927</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.209115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>405</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>56.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>0.256763</td>\n",
       "      <td>0.504752</td>\n",
       "      <td>0.023565</td>\n",
       "      <td>0.019415</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.261693</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>406</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>93.33</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>0.251587</td>\n",
       "      <td>0.485192</td>\n",
       "      <td>0.021985</td>\n",
       "      <td>0.019563</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.252921</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>407</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>112.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>0.256999</td>\n",
       "      <td>0.453208</td>\n",
       "      <td>0.024429</td>\n",
       "      <td>0.019706</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.244879</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>408</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>130.67</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>0.228192</td>\n",
       "      <td>0.477389</td>\n",
       "      <td>0.022218</td>\n",
       "      <td>0.020248</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.242600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>409</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>168.00</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>0.261018</td>\n",
       "      <td>0.469308</td>\n",
       "      <td>0.024954</td>\n",
       "      <td>0.019667</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.251760</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>410</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>56.00</td>\n",
       "      <td>fixed</td>\n",
       "      <td>1</td>\n",
       "      <td>0.256763</td>\n",
       "      <td>0.504752</td>\n",
       "      <td>0.023565</td>\n",
       "      <td>0.019415</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.261693</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>411</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>74.67</td>\n",
       "      <td>fixed</td>\n",
       "      <td>1</td>\n",
       "      <td>0.260419</td>\n",
       "      <td>0.463694</td>\n",
       "      <td>0.025720</td>\n",
       "      <td>0.019565</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.249944</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>412</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>93.33</td>\n",
       "      <td>fixed</td>\n",
       "      <td>1</td>\n",
       "      <td>0.251587</td>\n",
       "      <td>0.485192</td>\n",
       "      <td>0.021985</td>\n",
       "      <td>0.019563</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.252921</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>413</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>112.00</td>\n",
       "      <td>fixed</td>\n",
       "      <td>1</td>\n",
       "      <td>0.256999</td>\n",
       "      <td>0.453208</td>\n",
       "      <td>0.024429</td>\n",
       "      <td>0.019706</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.244879</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>414</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>130.67</td>\n",
       "      <td>fixed</td>\n",
       "      <td>1</td>\n",
       "      <td>0.228192</td>\n",
       "      <td>0.477389</td>\n",
       "      <td>0.022218</td>\n",
       "      <td>0.020248</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.242600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>415</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>149.33</td>\n",
       "      <td>fixed</td>\n",
       "      <td>1</td>\n",
       "      <td>0.267932</td>\n",
       "      <td>0.501595</td>\n",
       "      <td>0.025422</td>\n",
       "      <td>0.019711</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.264983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>416</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>168.00</td>\n",
       "      <td>fixed</td>\n",
       "      <td>1</td>\n",
       "      <td>0.261018</td>\n",
       "      <td>0.469308</td>\n",
       "      <td>0.024954</td>\n",
       "      <td>0.019667</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.251760</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>417</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>18.67</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>0.236255</td>\n",
       "      <td>0.222341</td>\n",
       "      <td>0.015903</td>\n",
       "      <td>0.061971</td>\n",
       "      <td>0.034188</td>\n",
       "      <td>0.158166</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>418</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>37.33</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>0.084258</td>\n",
       "      <td>0.103834</td>\n",
       "      <td>0.003599</td>\n",
       "      <td>0.022586</td>\n",
       "      <td>0.649573</td>\n",
       "      <td>0.063897</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>419</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>56.00</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>0.033647</td>\n",
       "      <td>0.078455</td>\n",
       "      <td>0.003170</td>\n",
       "      <td>0.019076</td>\n",
       "      <td>0.982906</td>\n",
       "      <td>0.038424</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>420</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>74.67</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>0.033647</td>\n",
       "      <td>0.078455</td>\n",
       "      <td>0.003170</td>\n",
       "      <td>0.019076</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.038424</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>421</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>93.33</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>0.033647</td>\n",
       "      <td>0.078455</td>\n",
       "      <td>0.003170</td>\n",
       "      <td>0.019076</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.038424</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>422</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>112.00</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>0.033647</td>\n",
       "      <td>0.078455</td>\n",
       "      <td>0.003170</td>\n",
       "      <td>0.019076</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.038424</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>423</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>130.67</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>0.033647</td>\n",
       "      <td>0.078455</td>\n",
       "      <td>0.003170</td>\n",
       "      <td>0.019076</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.038424</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>424</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>149.33</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>0.033647</td>\n",
       "      <td>0.078455</td>\n",
       "      <td>0.003170</td>\n",
       "      <td>0.019076</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.038424</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>425</th>\n",
       "      <td>enzymes</td>\n",
       "      <td>ntriangles</td>\n",
       "      <td>168.00</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>0.033647</td>\n",
       "      <td>0.078455</td>\n",
       "      <td>0.003170</td>\n",
       "      <td>0.019076</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.038424</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     dataset  constraint   param method method_param    degree   cluster  \\\n",
       "383  enzymes  ntriangles   18.67   poly          0|1  0.056174  0.298395   \n",
       "384  enzymes  ntriangles   37.33   poly          0|1  0.189586  0.425561   \n",
       "385  enzymes  ntriangles   56.00   poly          0|1  0.256763  0.504752   \n",
       "386  enzymes  ntriangles   74.67   poly          0|1  0.260419  0.463694   \n",
       "387  enzymes  ntriangles   93.33   poly          0|1  0.251587  0.485192   \n",
       "388  enzymes  ntriangles  168.00   poly          0|1  0.261018  0.469308   \n",
       "389  enzymes  ntriangles   18.67   poly          0|5  0.056174  0.298395   \n",
       "390  enzymes  ntriangles   37.33   poly          0|5  0.189586  0.425561   \n",
       "391  enzymes  ntriangles   56.00   poly          0|5  0.256763  0.504752   \n",
       "392  enzymes  ntriangles   93.33   poly          0|5  0.251587  0.485192   \n",
       "393  enzymes  ntriangles  112.00   poly          0|5  0.256999  0.453208   \n",
       "394  enzymes  ntriangles  149.33   poly          0|5  0.267932  0.501595   \n",
       "395  enzymes  ntriangles  168.00   poly          0|5  0.261018  0.469308   \n",
       "396  enzymes  ntriangles   37.33   poly        0.1|1  0.189586  0.425561   \n",
       "397  enzymes  ntriangles   56.00   poly        0.1|1  0.256763  0.504752   \n",
       "398  enzymes  ntriangles   74.67   poly        0.1|1  0.260419  0.463694   \n",
       "399  enzymes  ntriangles   93.33   poly        0.1|1  0.251587  0.485192   \n",
       "400  enzymes  ntriangles  112.00   poly        0.1|1  0.256999  0.453208   \n",
       "401  enzymes  ntriangles  149.33   poly        0.1|1  0.267932  0.501595   \n",
       "402  enzymes  ntriangles  168.00   poly        0.1|1  0.261018  0.469308   \n",
       "403  enzymes  ntriangles   18.67   poly        0.1|5  0.056174  0.298395   \n",
       "404  enzymes  ntriangles   37.33   poly        0.1|5  0.189586  0.425561   \n",
       "405  enzymes  ntriangles   56.00   poly        0.1|5  0.256763  0.504752   \n",
       "406  enzymes  ntriangles   93.33   poly        0.1|5  0.251587  0.485192   \n",
       "407  enzymes  ntriangles  112.00   poly        0.1|5  0.256999  0.453208   \n",
       "408  enzymes  ntriangles  130.67   poly        0.1|5  0.228192  0.477389   \n",
       "409  enzymes  ntriangles  168.00   poly        0.1|5  0.261018  0.469308   \n",
       "410  enzymes  ntriangles   56.00  fixed            1  0.256763  0.504752   \n",
       "411  enzymes  ntriangles   74.67  fixed            1  0.260419  0.463694   \n",
       "412  enzymes  ntriangles   93.33  fixed            1  0.251587  0.485192   \n",
       "413  enzymes  ntriangles  112.00  fixed            1  0.256999  0.453208   \n",
       "414  enzymes  ntriangles  130.67  fixed            1  0.228192  0.477389   \n",
       "415  enzymes  ntriangles  149.33  fixed            1  0.267932  0.501595   \n",
       "416  enzymes  ntriangles  168.00  fixed            1  0.261018  0.469308   \n",
       "417  enzymes  ntriangles   18.67   none            0  0.236255  0.222341   \n",
       "418  enzymes  ntriangles   37.33   none            0  0.084258  0.103834   \n",
       "419  enzymes  ntriangles   56.00   none            0  0.033647  0.078455   \n",
       "420  enzymes  ntriangles   74.67   none            0  0.033647  0.078455   \n",
       "421  enzymes  ntriangles   93.33   none            0  0.033647  0.078455   \n",
       "422  enzymes  ntriangles  112.00   none            0  0.033647  0.078455   \n",
       "423  enzymes  ntriangles  130.67   none            0  0.033647  0.078455   \n",
       "424  enzymes  ntriangles  149.33   none            0  0.033647  0.078455   \n",
       "425  enzymes  ntriangles  168.00   none            0  0.033647  0.078455   \n",
       "\n",
       "        orbit  spectral  constr_val        av  \n",
       "383  0.027567  0.062189    0.965812  0.127379  \n",
       "384  0.012198  0.022927    1.000000  0.209115  \n",
       "385  0.023565  0.019415    1.000000  0.261693  \n",
       "386  0.025720  0.019565    1.000000  0.249944  \n",
       "387  0.021985  0.019563    1.000000  0.252921  \n",
       "388  0.024954  0.019667    1.000000  0.251760  \n",
       "389  0.027567  0.062189    0.965812  0.127379  \n",
       "390  0.012198  0.022927    1.000000  0.209115  \n",
       "391  0.023565  0.019415    1.000000  0.261693  \n",
       "392  0.021985  0.019563    1.000000  0.252921  \n",
       "393  0.024429  0.019706    1.000000  0.244879  \n",
       "394  0.025422  0.019711    1.000000  0.264983  \n",
       "395  0.024954  0.019667    1.000000  0.251760  \n",
       "396  0.012198  0.022927    1.000000  0.209115  \n",
       "397  0.023565  0.019415    1.000000  0.261693  \n",
       "398  0.025720  0.019565    1.000000  0.249944  \n",
       "399  0.021985  0.019563    1.000000  0.252921  \n",
       "400  0.024429  0.019706    1.000000  0.244879  \n",
       "401  0.025422  0.019711    1.000000  0.264983  \n",
       "402  0.024954  0.019667    1.000000  0.251760  \n",
       "403  0.027567  0.062189    0.965812  0.127379  \n",
       "404  0.012198  0.022927    1.000000  0.209115  \n",
       "405  0.023565  0.019415    1.000000  0.261693  \n",
       "406  0.021985  0.019563    1.000000  0.252921  \n",
       "407  0.024429  0.019706    1.000000  0.244879  \n",
       "408  0.022218  0.020248    1.000000  0.242600  \n",
       "409  0.024954  0.019667    1.000000  0.251760  \n",
       "410  0.023565  0.019415    1.000000  0.261693  \n",
       "411  0.025720  0.019565    1.000000  0.249944  \n",
       "412  0.021985  0.019563    1.000000  0.252921  \n",
       "413  0.024429  0.019706    1.000000  0.244879  \n",
       "414  0.022218  0.020248    1.000000  0.242600  \n",
       "415  0.025422  0.019711    1.000000  0.264983  \n",
       "416  0.024954  0.019667    1.000000  0.251760  \n",
       "417  0.015903  0.061971    0.034188  0.158166  \n",
       "418  0.003599  0.022586    0.649573  0.063897  \n",
       "419  0.003170  0.019076    0.982906  0.038424  \n",
       "420  0.003170  0.019076    1.000000  0.038424  \n",
       "421  0.003170  0.019076    1.000000  0.038424  \n",
       "422  0.003170  0.019076    1.000000  0.038424  \n",
       "423  0.003170  0.019076    1.000000  0.038424  \n",
       "424  0.003170  0.019076    1.000000  0.038424  \n",
       "425  0.003170  0.019076    1.000000  0.038424  "
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.loc[(df['dataset'] == 'enzymes') & (df['constraint'] == 'ntriangles') & (df['param'])]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.3354886666666667"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sum([0.538817\t1.095732\t0.014662])/3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv ('all_results/all_mol_results_bisect4.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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>dataset</th>\n",
       "      <th>constraint</th>\n",
       "      <th>param</th>\n",
       "      <th>method</th>\n",
       "      <th>method_param</th>\n",
       "      <th>valid</th>\n",
       "      <th>unique</th>\n",
       "      <th>fcd</th>\n",
       "      <th>novelty</th>\n",
       "      <th>nspdk</th>\n",
       "      <th>num_mols</th>\n",
       "      <th>constr_val</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S2Cl1Br1I1</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>31.263171</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.112324</td>\n",
       "      <td>9996</td>\n",
       "      <td>0.998800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S4Cl1Br1I1</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>30.963419</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.109891</td>\n",
       "      <td>9995</td>\n",
       "      <td>0.999300</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S6Cl1Br1I1</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>31.664835</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.106672</td>\n",
       "      <td>9985</td>\n",
       "      <td>0.998398</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P5S2Cl1Br1I1</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>31.003181</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.110407</td>\n",
       "      <td>9992</td>\n",
       "      <td>0.999199</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S2Cl1Br1I1</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>30.225838</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.099842</td>\n",
       "      <td>9989</td>\n",
       "      <td>0.998398</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S4Cl1Br1I1</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>29.669601</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.096065</td>\n",
       "      <td>9988</td>\n",
       "      <td>0.998698</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P5S2Cl1Br1I1</td>\n",
       "      <td>poly</td>\n",
       "      <td>0|5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>29.791738</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.094749</td>\n",
       "      <td>9988</td>\n",
       "      <td>0.998899</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S4Cl1Br1I1</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>30.032474</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.092631</td>\n",
       "      <td>9991</td>\n",
       "      <td>0.997998</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S6Cl1Br1I1</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9999</td>\n",
       "      <td>30.817280</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.089024</td>\n",
       "      <td>9984</td>\n",
       "      <td>0.997596</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S4Cl1Br1I1</td>\n",
       "      <td>fixed</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9999</td>\n",
       "      <td>31.005818</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.118143</td>\n",
       "      <td>9982</td>\n",
       "      <td>0.999199</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P5S2Cl1Br1I1</td>\n",
       "      <td>fixed</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9999</td>\n",
       "      <td>31.092603</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.117824</td>\n",
       "      <td>9993</td>\n",
       "      <td>0.999199</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S2Cl1Br1I1</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9964</td>\n",
       "      <td>14.042862</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.017848</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.942500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S4Cl1Br1I1</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9964</td>\n",
       "      <td>14.030862</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.017759</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.948800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P3S6Cl1Br1I1</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9964</td>\n",
       "      <td>15.228577</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.017463</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.949400</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P5S2Cl1Br1I1</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9964</td>\n",
       "      <td>14.042862</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.017848</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.942500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P5S4Cl1Br1I1</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9964</td>\n",
       "      <td>14.030862</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.017759</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.948800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>valency</td>\n",
       "      <td>C4N3O2F1P5S6Cl1Br1I1</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9964</td>\n",
       "      <td>15.228577</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.017463</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.949400</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>atomCount</td>\n",
       "      <td>C21N3O3F0P0S0Cl0Br0I0</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>12.052725</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.023899</td>\n",
       "      <td>9697</td>\n",
       "      <td>0.494689</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>atomCount</td>\n",
       "      <td>C19N4O2F0P0S0Cl0Br0I0</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>9.984711</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.017378</td>\n",
       "      <td>9663</td>\n",
       "      <td>0.339646</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>atomCount</td>\n",
       "      <td>C18N3O2F0P0S0Cl0Br0I0</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>7.176473</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.011004</td>\n",
       "      <td>9668</td>\n",
       "      <td>0.311233</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>atomCount</td>\n",
       "      <td>C19N3O3F0P0S0Cl0Br0I0</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>8.192061</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.011466</td>\n",
       "      <td>9643</td>\n",
       "      <td>0.437208</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>atomCount</td>\n",
       "      <td>C16N3O2F0P0S0Cl0Br0I0</td>\n",
       "      <td>poly</td>\n",
       "      <td>0.1|5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>6.431816</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.009365</td>\n",
       "      <td>9657</td>\n",
       "      <td>0.179352</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>atomCount</td>\n",
       "      <td>C21N3O3F0P0S0Cl0Br0I0</td>\n",
       "      <td>fixed</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>13.230597</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.030278</td>\n",
       "      <td>9651</td>\n",
       "      <td>0.451249</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>atomCount</td>\n",
       "      <td>C18N3O3F0P0S0Cl0Br0I0</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9964</td>\n",
       "      <td>6.855752</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.008277</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.474400</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>atomCount</td>\n",
       "      <td>C20N3O2F0P0S0Cl0Br0I0</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9964</td>\n",
       "      <td>6.369290</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.006666</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.510600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>zinc250k</td>\n",
       "      <td>atomCount</td>\n",
       "      <td>C18N3O2F0P0S0Cl0Br0I0</td>\n",
       "      <td>none</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.9964</td>\n",
       "      <td>5.952909</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.006407</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.424500</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     dataset constraint                  param method method_param  valid  \\\n",
       "0   zinc250k    valency   C4N3O2F1P3S2Cl1Br1I1   poly          0|1    1.0   \n",
       "1   zinc250k    valency   C4N3O2F1P3S4Cl1Br1I1   poly          0|1    1.0   \n",
       "2   zinc250k    valency   C4N3O2F1P3S6Cl1Br1I1   poly          0|1    1.0   \n",
       "3   zinc250k    valency   C4N3O2F1P5S2Cl1Br1I1   poly          0|1    1.0   \n",
       "4   zinc250k    valency   C4N3O2F1P3S2Cl1Br1I1   poly          0|5    1.0   \n",
       "5   zinc250k    valency   C4N3O2F1P3S4Cl1Br1I1   poly          0|5    1.0   \n",
       "6   zinc250k    valency   C4N3O2F1P5S2Cl1Br1I1   poly          0|5    1.0   \n",
       "7   zinc250k    valency   C4N3O2F1P3S4Cl1Br1I1   poly        0.1|5    1.0   \n",
       "8   zinc250k    valency   C4N3O2F1P3S6Cl1Br1I1   poly        0.1|5    1.0   \n",
       "9   zinc250k    valency   C4N3O2F1P3S4Cl1Br1I1  fixed            1    1.0   \n",
       "10  zinc250k    valency   C4N3O2F1P5S2Cl1Br1I1  fixed            1    1.0   \n",
       "11  zinc250k    valency   C4N3O2F1P3S2Cl1Br1I1   none            0    1.0   \n",
       "12  zinc250k    valency   C4N3O2F1P3S4Cl1Br1I1   none            0    1.0   \n",
       "13  zinc250k    valency   C4N3O2F1P3S6Cl1Br1I1   none            0    1.0   \n",
       "14  zinc250k    valency   C4N3O2F1P5S2Cl1Br1I1   none            0    1.0   \n",
       "15  zinc250k    valency   C4N3O2F1P5S4Cl1Br1I1   none            0    1.0   \n",
       "16  zinc250k    valency   C4N3O2F1P5S6Cl1Br1I1   none            0    1.0   \n",
       "17  zinc250k  atomCount  C21N3O3F0P0S0Cl0Br0I0   poly        0.1|1    1.0   \n",
       "18  zinc250k  atomCount  C19N4O2F0P0S0Cl0Br0I0   poly        0.1|1    1.0   \n",
       "19  zinc250k  atomCount  C18N3O2F0P0S0Cl0Br0I0   poly        0.1|5    1.0   \n",
       "20  zinc250k  atomCount  C19N3O3F0P0S0Cl0Br0I0   poly        0.1|5    1.0   \n",
       "21  zinc250k  atomCount  C16N3O2F0P0S0Cl0Br0I0   poly        0.1|5    1.0   \n",
       "22  zinc250k  atomCount  C21N3O3F0P0S0Cl0Br0I0  fixed            1    1.0   \n",
       "23  zinc250k  atomCount  C18N3O3F0P0S0Cl0Br0I0   none            0    1.0   \n",
       "24  zinc250k  atomCount  C20N3O2F0P0S0Cl0Br0I0   none            0    1.0   \n",
       "25  zinc250k  atomCount  C18N3O2F0P0S0Cl0Br0I0   none            0    1.0   \n",
       "\n",
       "    unique        fcd  novelty     nspdk  num_mols  constr_val  \n",
       "0   1.0000  31.263171      1.0  0.112324      9996    0.998800  \n",
       "1   1.0000  30.963419      1.0  0.109891      9995    0.999300  \n",
       "2   1.0000  31.664835      1.0  0.106672      9985    0.998398  \n",
       "3   1.0000  31.003181      1.0  0.110407      9992    0.999199  \n",
       "4   1.0000  30.225838      1.0  0.099842      9989    0.998398  \n",
       "5   1.0000  29.669601      1.0  0.096065      9988    0.998698  \n",
       "6   1.0000  29.791738      1.0  0.094749      9988    0.998899  \n",
       "7   1.0000  30.032474      1.0  0.092631      9991    0.997998  \n",
       "8   0.9999  30.817280      1.0  0.089024      9984    0.997596  \n",
       "9   0.9999  31.005818      1.0  0.118143      9982    0.999199  \n",
       "10  0.9999  31.092603      1.0  0.117824      9993    0.999199  \n",
       "11  0.9964  14.042862      1.0  0.017848     10000    0.942500  \n",
       "12  0.9964  14.030862      1.0  0.017759     10000    0.948800  \n",
       "13  0.9964  15.228577      1.0  0.017463     10000    0.949400  \n",
       "14  0.9964  14.042862      1.0  0.017848     10000    0.942500  \n",
       "15  0.9964  14.030862      1.0  0.017759     10000    0.948800  \n",
       "16  0.9964  15.228577      1.0  0.017463     10000    0.949400  \n",
       "17  1.0000  12.052725      1.0  0.023899      9697    0.494689  \n",
       "18  1.0000   9.984711      1.0  0.017378      9663    0.339646  \n",
       "19  1.0000   7.176473      1.0  0.011004      9668    0.311233  \n",
       "20  1.0000   8.192061      1.0  0.011466      9643    0.437208  \n",
       "21  1.0000   6.431816      1.0  0.009365      9657    0.179352  \n",
       "22  1.0000  13.230597      1.0  0.030278      9651    0.451249  \n",
       "23  0.9964   6.855752      1.0  0.008277     10000    0.474400  \n",
       "24  0.9964   6.369290      1.0  0.006666     10000    0.510600  \n",
       "25  0.9964   5.952909      1.0  0.006407     10000    0.424500  "
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv ('all_results/all_mol_results_bisect4.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "smiles_file = 'logs_sample/QM9/test/Atom-Count/gdss_qm9-proj-1p0-bisect-fixed1-0-0-[9, 0, 9, 0]-none.txt'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "smiles_file = 'logs_sample/ZINC250k/test/Atom-Count/gdss_zinc250k-proj-1p0-bisect-fixed1-0-0-[36, 0, 3, 0, 0, 0, 0, 0, 0]-none.txt'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "gen_smiles = []\n",
    "with open (f\"{smiles_file}\", 'r') as f:\n",
    "    for line in f:\n",
    "        gen_smiles.append(line[:-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils.mol_utils import load_smiles\n",
    "_, test_smiles = load_smiles('ZINC250k', file_ext='_can')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "fps_test = [FingerprintMols.FingerprintMol(Chem.MolFromSmiles(x)) for x in test_smiles]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "fps_gen = [FingerprintMols.FingerprintMol(Chem.MolFromSmiles(x)) for x in gen_smiles]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [],
   "source": [
    "from rdkit import Chem\n",
    "from rdkit import DataStructs\n",
    "from rdkit.Chem.Fingerprints import FingerprintMols\n",
    "\n",
    "sims = []\n",
    "smiles = []\n",
    "i = 0\n",
    "\n",
    "for fp, gs in zip(fps_gen, gen_smiles):\n",
    "    sims.append(max(DataStructs.BulkTanimotoSimilarity(fp, fps_test)))\n",
    "    smiles.append(gs)\n",
    "    i += 1\n",
    "    if i > 1000:\n",
    "        break\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [],
   "source": [
    "sorted_inds = sorted (list(range(len(smiles))), key=lambda i: sims[i], reverse=True)\n",
    "sorted_smiles = [smiles[j] for j in sorted_inds if sims[j] != 1][:10]\n",
    "sorted_sims = [sims[j] for j in sorted_inds if sims[j] != 1][:10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[('CC1CC2C(=O)CC3CCCCC1CC2C(C)CC3', 0.9423076923076923),\n",
       " ('CCCC(C)CC1CCC(C)CC(C(C)=O)C2CCCCC12', 0.9038461538461539),\n",
       " ('CC1CCCCCCCC2CCC3CCCC(=O)C2C13.c1ccccc1', 0.875),\n",
       " ('COC1CCCC(C)(C)CC2CC1C(C)CO2', 0.8145695364238411),\n",
       " ('CC(C)CCCC1CCCC1C(=O)CC(C)C1(C)CCC1.O', 0.8120300751879699),\n",
       " ('CC1CC2CCCC2C1C.O=C1CCC2CCC1C2', 0.8108108108108109),\n",
       " ('CCC1CCCC2CCCCCOC(C1)C2', 0.8),\n",
       " ('CCCCCCC(CC(C)CC)C(=O)C(C)C', 0.8),\n",
       " ('CCCC(C)CC(C)CCc1ccccc1', 0.8),\n",
       " ('CCCCC(C)CC(O)C1CCC1CC1CCCC1C', 0.7983870967741935)]"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "list(zip(sorted_smiles, sorted_sims))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import copy\n",
    "from rdkit import Chem\n",
    "from rdkit.Chem import RDConfig\n",
    "from rdkit.Chem import AllChem\n",
    "from rdkit.Chem import Draw\n",
    "from rdkit.Chem.Draw import rdDepictor, rdMolDraw2D\n",
    "opts = Draw.DrawingOptions()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [],
   "source": [
    "mols = smiles_to_mols (sorted_smiles)\n",
    "mols2D = copy.deepcopy(mols)\n",
    "for m in mols2D:\n",
    "    AllChem.Compute2DCoords(m)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=1000x400>"
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Draw.MolsToGridImage(mols2D[:10], molsPerRow=5)"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "44dc670dcdd6ffb1ba23034ae072504999a2c20bd6cc686fd82920ca8c3f3b47"
  },
  "kernelspec": {
   "display_name": "Python 3.7.15 64-bit ('moltemp': conda)",
   "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.7.15"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
