{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "def extract_violation(filename):\n",
    "    # Open the file for reading\n",
    "    with open(filename, 'r') as file:\n",
    "        # Read the entire content of the file\n",
    "        content = file.read()\n",
    "\n",
    "    # Find all occurrences of the target string followed by a number\n",
    "    import re\n",
    "    # pattern = r' the cost before round is  (\\\\\\\\d+(\\\\\\\\.\\\\\\\\d+)?)'\n",
    "    pattern = r' the violation is  (\\d+(\\.\\d+)?)'\n",
    "    matches = re.findall(pattern, content)\n",
    "\n",
    "    # Extract the numbers from the matches\n",
    "    numbers = [float(match[0]) for match in matches]\n",
    "\n",
    "    return numbers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[1.28,\n",
       " 8.16,\n",
       " 0.9199999999999999,\n",
       " 9.120000000000001,\n",
       " 0.9199999999999999,\n",
       " 7.38,\n",
       " 0.9199999999999999,\n",
       " 4.5600000000000005]"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "extract_violation('output/round_hypercube.txt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.5800000000000001,\n",
       " 5.94,\n",
       " 0.7000000000000002,\n",
       " 5.28,\n",
       " 0.98,\n",
       " 3.3000000000000003,\n",
       " 0.98,\n",
       " 2.64,\n",
       " 1.28,\n",
       " 8.16,\n",
       " 0.9199999999999999,\n",
       " 9.120000000000001,\n",
       " 0.9199999999999999,\n",
       " 7.38,\n",
       " 0.9199999999999999,\n",
       " 4.5600000000000005,\n",
       " 0.9199999999999999,\n",
       " 5.6,\n",
       " 0.8999999999999999,\n",
       " 5.16,\n",
       " 1.02,\n",
       " 4.3,\n",
       " 0.94,\n",
       " 3.6,\n",
       " 1.1,\n",
       " 5.04,\n",
       " 0.8999999999999999,\n",
       " 5.04,\n",
       " 1.0,\n",
       " 5.04,\n",
       " 1.1600000000000001,\n",
       " 5.04]"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "filelist = ['output/round_moons.txt', 'output/round_hypercube.txt', 'output/round_balanced_cluto.txt', 'output/round_balanced_complex.txt']\n",
    "res = []\n",
    "for f in filelist:\n",
    "    res = res + extract_violation(f)\n",
    "res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.5800000000000001, 5.94, 0.7000000000000002, 5.28, 0.98, 3.3000000000000003, 0.98, 2.64, 1.28, 8.16, 0.9199999999999999, 9.120000000000001, 0.9199999999999999, 7.38, 0.9199999999999999, 4.5600000000000005, 0.9199999999999999, 5.6, 0.8999999999999999, 5.16, 1.02, 4.3, 0.94, 3.6, 1.1, 5.04, 0.8999999999999999, 5.04, 1.0, 5.04, 1.1600000000000001, 5.04]\n"
     ]
    }
   ],
   "source": [
    "len(res)\n",
    "print(res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "ename": "IndexError",
     "evalue": "Replacement index 32 out of range for positional args tuple",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mIndexError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[57], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m template \u001b[39m=\u001b[39m \u001b[39m'''\u001b[39;49m\n\u001b[1;32m      2\u001b[0m \u001b[39m\\\\\u001b[39;49;00m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mbegin\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mtable}}}}[]\u001b[39;49m\n\u001b[1;32m      3\u001b[0m \u001b[39m\\\\\u001b[39;49;00m\u001b[39mbegin\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mtable}}[]\u001b[39;49m\n\u001b[1;32m      4\u001b[0m \u001b[39m\\\\\u001b[39;49;00m\u001b[39mbegin\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mtabular}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mcccccccccclll}}\u001b[39;49m\n\u001b[1;32m      5\u001b[0m \u001b[39m\\\\\u001b[39;49;00m\u001b[39mtextbf\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mdataset}} & \u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mmulticolumn\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m2}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mc}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mtextbf\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m2}}}} & \u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mmulticolumn\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m2}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mc}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mtextbf\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m3}}}} & \u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mmulticolumn\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m2}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mc}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mtextbf\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m4}}}} & \u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mmulticolumn\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m2}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mc}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mtextbf\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m5}}}} & \u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mmulticolumn\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m2}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mc}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mtextbf\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m6}}}} & \u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mmulticolumn\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m2}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mc}}\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39mtextbf\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39m7}}}} \u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39m\\\\\u001b[39;49;00m\n\u001b[1;32m      6\u001b[0m \u001b[39mmoons            &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      \u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39m\\\\\u001b[39;49;00m\n\u001b[1;32m      7\u001b[0m \u001b[39mhypercube        &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      \u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39m\\\\\u001b[39;49;00m\n\u001b[1;32m      8\u001b[0m \u001b[39mcomplex          &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      \u001b[39;49m\u001b[39m\\\\\u001b[39;49;00m\u001b[39m\\\\\u001b[39;49;00m\n\u001b[1;32m      9\u001b[0m \u001b[39mcluto            &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m      &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m       &         \u001b[39;49m\u001b[39m{:.2f}\u001b[39;49;00m\u001b[39m     \u001b[39;49m\n\u001b[1;32m     10\u001b[0m \u001b[39m\\\\\u001b[39;49;00m\u001b[39mend\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mtabular}}\u001b[39;49m\n\u001b[1;32m     11\u001b[0m \u001b[39m\\\\\u001b[39;49;00m\u001b[39mend\u001b[39;49m\u001b[39m{{\u001b[39;49m\u001b[39mtable}}\u001b[39;49m\n\u001b[1;32m     12\u001b[0m \u001b[39m'''\u001b[39;49m\u001b[39m.\u001b[39;49mformat(\u001b[39m*\u001b[39;49mres)\n\u001b[1;32m     13\u001b[0m template\n",
      "\u001b[0;31mIndexError\u001b[0m: Replacement index 32 out of range for positional args tuple"
     ]
    }
   ],
   "source": [
    "template = '''\n",
    "\\\\\\\\begin{{{{table}}}}[]\n",
    "\\\\begin{{table}}[]\n",
    "\\\\begin{{tabular}}{{cccccccccclll}}\n",
    "\\\\textbf{{dataset}} & \\\\multicolumn{{2}}{{c}}{{\\\\textbf{{2}}}} & \\\\multicolumn{{2}}{{c}}{{\\\\textbf{{3}}}} & \\\\multicolumn{{2}}{{c}}{{\\\\textbf{{4}}}} & \\\\multicolumn{{2}}{{c}}{{\\\\textbf{{5}}}} & \\\\multicolumn{{2}}{{c}}{{\\\\textbf{{6}}}} & \\\\multicolumn{{2}}{{c}}{{\\\\textbf{{7}}}} \\\\\\\\\n",
    "moons            &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      \\\\\\\\\n",
    "hypercube        &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      \\\\\\\\\n",
    "complex          &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      \\\\\\\\\n",
    "cluto            &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}      &         {:.2f}       &         {:.2f}     \n",
    "\\\\end{{tabular}}\n",
    "\\\\end{{table}}\n",
    "'''.format(*res)\n",
    "template"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\\\\begin{{table}}[]\n",
      "\\begin{table}[]\n",
      "\\begin{tabular}{cccccccccclll}\n",
      "\\textbf{dataset} & \\multicolumn{2}{c}{\\textbf{2}} & \\multicolumn{2}{c}{\\textbf{3}} & \\multicolumn{2}{c}{\\textbf{4}} & \\multicolumn{2}{c}{\\textbf{5}} & \\multicolumn{2}{c}{\\textbf{6}} & \\multicolumn{2}{c}{\\textbf{7}} \\\\\n",
      "moons            &         0.00       &         32.00      &         0.00       &         44.00      &         0.00       &         26.00      &         0.00       &         25.00      &         0.00       &         20.00      &         0.00       &         17.00      \\\\\n",
      "hypercube        &         0.00       &         15.50      &         0.00       &         15.50      &         0.00       &         13.50      &         0.00       &         11.00      &         0.00       &         11.50      &         0.00       &         11.00      \\\\\n",
      "complex          &         0.00       &         10.50      &         0.00       &         12.50      &         0.00       &         50.00      &         0.00       &         75.00      &         0.00       &         75.00      &         0.00       &         87.50      \\\\\n",
      "cluto            &         0.00       &         87.50      &         0.00       &         87.50      &         0.88       &         87.50      &         0.88       &         87.50      &         0.88       &         87.50      &         1.25       &         87.50     \n",
      "\\end{tabular}\n",
      "\\end{table}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(template)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ph",
   "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.13"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
