{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Default setting\n",
    "\n",
    "# for res in [2, 5, 10]:\n",
    "\n",
    "res = 5\n",
    "cov_weight = 0.5\n",
    "r2_list = [0, 1]  # Row 1: r2=0, Row 2: r2=1\n",
    "p_list = [0.1, 0.3, 0.5]\n",
    "estm_name = [\"Hájek\", \"CAE\", \"MII\", \"GNN\", \"AMII\"]\n",
    "\n",
    "# Loop through r2 and metrics\n",
    "for row, r2 in enumerate(r2_list):\n",
    "    # Load data\n",
    "    bias_array = []\n",
    "    std_array = []\n",
    "    mse_array = []\n",
    "    for p2 in p_list:\n",
    "        estm_list = torch.load(f\"result/estm_list_res{res}_p{p2}_cov{cov_weight}_r2{r2}.pkl\")\n",
    "        bias_array.append(list(map(lambda x: x.mean(), estm_list)))\n",
    "        std_array.append(list(map(lambda x: x.std(), estm_list)))\n",
    "        mse_array.append(list(map(lambda x: x.mean()**2 + x.var(), estm_list)))\n",
    "    \n",
    "    bias_array = np.abs(np.array(bias_array))\n",
    "    std_array = np.array(std_array)\n",
    "    mse_array = np.array(mse_array)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All tables generated successfully!\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "# Parameters\n",
    "res = 5\n",
    "cov_weight = 0.5\n",
    "r2_list = [0, 1]  # Will generate two tables\n",
    "p_list = [0.1, 0.3, 0.5]\n",
    "estm_name = [\"Hájek\", \"CAE\", \"MII\", \"GNN\", \"AMII\"]\n",
    "\n",
    "# Initialize data storage\n",
    "# We'll use dictionary comprehension for better readability\n",
    "data = {\n",
    "    r2: {\n",
    "        p: {\n",
    "            'bias': [],\n",
    "            'std': [],\n",
    "            'mse': []\n",
    "        } for p in p_list\n",
    "    } for r2 in r2_list\n",
    "}\n",
    "\n",
    "# Load data for all combinations\n",
    "for r2 in r2_list:\n",
    "    for p in p_list:\n",
    "        # Load estimator results\n",
    "        estm_list = torch.load(f\"result/estm_list_res{res}_p{p}_cov{cov_weight}_r2{r2}.pkl\")\n",
    "        \n",
    "        # Calculate metrics for each estimator\n",
    "        for estm in estm_list:\n",
    "            data[r2][p]['bias'].append(np.abs(np.mean(estm)))\n",
    "            data[r2][p]['std'].append(np.std(estm))\n",
    "            data[r2][p]['mse'].append(np.mean(estm)**2 + np.var(estm))\n",
    "\n",
    "# Generate LaTeX tables - one per r2 value\n",
    "for r2 in r2_list:\n",
    "    latex_table = fr\"\"\"\n",
    "\\begin{{table}}[ht]\n",
    "    \\centering\n",
    "    \\caption{{Statistical performance ($r_2 = {r2}$, $\\gamma = {res}$)}}\n",
    "    \\begin{{tabular}}{{l ccc c ccc c ccc}}\n",
    "    \\toprule\n",
    "    ${{p}}$ & \\multicolumn{{3}}{{c}}{{0.1}} && \\multicolumn{{3}}{{c}}{{0.3}} && \\multicolumn{{3}}{{c}}{{0.5}} \\\\    \n",
    "    \\textbf{{Metric}} & Bias & Std & MSE && Bias & Std & MSE && Bias & Std & MSE \\\\\n",
    "    \\textbf{{Estimators}} &        &        &        &&        &        &  &&        &        &     \\\\        \n",
    "    \\midrule\n",
    "\"\"\"\n",
    "\n",
    "    # Add data rows for each estimator\n",
    "    for i, name in enumerate(estm_name):\n",
    "        # Get values for all p values\n",
    "        values = []\n",
    "        for p in p_list:\n",
    "            values.extend([\n",
    "                data[r2][p]['bias'][i],\n",
    "                data[r2][p]['std'][i],\n",
    "                data[r2][p]['mse'][i]\n",
    "            ])\n",
    "        \n",
    "        # Format the row with double separators between p values\n",
    "        row = f\"    \\\\textbf{{{name}}} \"\n",
    "        for j, val in enumerate(values):\n",
    "            sep = \" && \" if (j) % 3 == 0 and j> 1 else \" & \"\n",
    "            row += f\"{sep}{val:.3f}\"\n",
    "        row += \" \\\\\\\\\"\n",
    "        latex_table += row + \"\\n\"\n",
    "\n",
    "    latex_table += r\"\"\"    \\bottomrule\n",
    "    \\end{tabular}\n",
    "\\end{table}\n",
    "\"\"\"\n",
    "\n",
    "    # Save to file\n",
    "    filename = 'Tables/res{}_covwgt{}.tex'.format(res, cov_weight)\n",
    "    with open(filename, 'a', encoding='utf-8') as f:\n",
    "        f.write(latex_table)\n",
    "\n",
    "print(\"All tables generated successfully!\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All tables generated successfully!\n",
      "All tables generated successfully!\n",
      "All tables generated successfully!\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "# Parameters\n",
    "\n",
    "cov_weight = 0.5\n",
    "r2_list = [0, 1]  # Will generate two tables\n",
    "p_list = [0.1, 0.3, 0.5]\n",
    "estm_name = [\"Hájek\", \"CAE\", \"MII\", \"GNN\", \"AMII\"]\n",
    "\n",
    "for res in [2, 5, 10]:\n",
    "\n",
    "    table_list = []\n",
    "\n",
    "    # Initialize data storage\n",
    "    # We'll use dictionary comprehension for better readability\n",
    "    data = {\n",
    "        r2: {\n",
    "            p: {\n",
    "                'bias': [],\n",
    "                'std': [],\n",
    "                'mse': []\n",
    "            } for p in p_list\n",
    "        } for r2 in r2_list\n",
    "    }\n",
    "\n",
    "    # Load data for all combinations\n",
    "    for r2 in r2_list:\n",
    "        for p in p_list:\n",
    "            # Load estimator results\n",
    "            estm_list = torch.load(f\"result/estm_list_res{res}_p{p}_cov{cov_weight}_r2{r2}.pkl\")\n",
    "            \n",
    "            # Calculate metrics for each estimator\n",
    "            for estm in estm_list:\n",
    "                data[r2][p]['bias'].append(np.abs(np.mean(estm)))\n",
    "                data[r2][p]['std'].append(np.std(estm))\n",
    "                data[r2][p]['mse'].append(np.mean(estm)**2 + np.var(estm))\n",
    "\n",
    "    # Generate LaTeX tables - one per r2 value\n",
    "    for r2 in r2_list:\n",
    "        latex_table = fr\"\"\"\n",
    "    \\begin{{table}}[ht]\n",
    "        \\centering\n",
    "        \\caption{{Statistical performance ($r_2 = {r2}$, $\\gamma = {res}$)}}\n",
    "        \\begin{{tabular}}{{l ccc c ccc c ccc}}\n",
    "        \\toprule\n",
    "        ${{p}}$ & \\multicolumn{{3}}{{c}}{{0.1}} && \\multicolumn{{3}}{{c}}{{0.3}} && \\multicolumn{{3}}{{c}}{{0.5}} \\\\    \n",
    "        \\textbf{{Metric}} & Bias & Std & MSE && Bias & Std & MSE && Bias & Std & MSE \\\\\n",
    "        \\textbf{{Estimators}} &        &        &        &&        &        &  &&        &        &     \\\\        \n",
    "        \\midrule\n",
    "    \"\"\"\n",
    "\n",
    "        # Add data rows for each estimator\n",
    "        for i, name in enumerate(estm_name):\n",
    "            # Get values for all p values\n",
    "            values = []\n",
    "            for p in p_list:\n",
    "                values.extend([\n",
    "                    data[r2][p]['bias'][i],\n",
    "                    data[r2][p]['std'][i],\n",
    "                    data[r2][p]['mse'][i]\n",
    "                ])\n",
    "            \n",
    "            # Format the row with double separators between p values\n",
    "            row = f\"    \\\\textbf{{{name}}} \"\n",
    "            for j, val in enumerate(values):\n",
    "                sep = \" && \" if (j) % 3 == 0 and j> 1 else \" & \"\n",
    "                row += f\"{sep}{val:.3f}\"\n",
    "            row += \" \\\\\\\\\"\n",
    "            latex_table += row + \"\\n\"\n",
    "\n",
    "        latex_table += r\"\"\"    \\bottomrule\n",
    "        \\end{tabular}\n",
    "    \\end{table}\n",
    "    \"\"\"\n",
    "        table_list.append(latex_table)\n",
    "    \n",
    "    \n",
    "    # Write    \n",
    "    filename = 'Tables/res{}_covwgt{}.tex'.format(res, cov_weight)\n",
    "    \n",
    "    with open(filename, 'w', encoding='utf-8') as f:\n",
    "        for table in table_list:\n",
    "            f.write(table + \"\\n\")\n",
    "\n",
    "    print(\"All tables generated successfully!\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# only1cov"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All tables generated successfully!\n",
      "All tables generated successfully!\n",
      "All tables generated successfully!\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "# Parameters\n",
    "\n",
    "cov_weight = 1\n",
    "r2_list = [0, 1]  # Will generate two tables\n",
    "p_list = [0.1, 0.3, 0.5]\n",
    "estm_name = [\"Hájek\", \"CAE\", \"MII\", \"GNN\", \"AMII\"]\n",
    "\n",
    "for res in [2, 5, 10]:\n",
    "\n",
    "    table_list = []\n",
    "\n",
    "    # Initialize data storage\n",
    "    # We'll use dictionary comprehension for better readability\n",
    "    data = {\n",
    "        r2: {\n",
    "            p: {\n",
    "                'bias': [],\n",
    "                'std': [],\n",
    "                'mse': []\n",
    "            } for p in p_list\n",
    "        } for r2 in r2_list\n",
    "    }\n",
    "\n",
    "    # Load data for all combinations\n",
    "    for r2 in r2_list:\n",
    "        for p in p_list:\n",
    "            # Load estimator results\n",
    "            estm_list = torch.load(f\"result/estm_list_res{res}_p{p}_cov{cov_weight}_r2{r2}_only1c.pkl\")\n",
    "            \n",
    "            # Calculate metrics for each estimator\n",
    "            for estm in estm_list:\n",
    "                data[r2][p]['bias'].append(np.abs(np.mean(estm)))\n",
    "                data[r2][p]['std'].append(np.std(estm))\n",
    "                data[r2][p]['mse'].append(np.mean(estm)**2 + np.var(estm))\n",
    "\n",
    "    # Generate LaTeX tables - one per r2 value\n",
    "    for r2 in r2_list:\n",
    "        latex_table = fr\"\"\"\n",
    "    \\begin{{table}}[ht]\n",
    "        \\centering\n",
    "        \\caption{{Statistical performance with one covariate ($r_2 = {r2}$, $\\gamma = {res}$)}}\n",
    "        \\begin{{tabular}}{{l ccc c ccc c ccc}}\n",
    "        \\toprule\n",
    "        ${{p}}$ & \\multicolumn{{3}}{{c}}{{0.1}} && \\multicolumn{{3}}{{c}}{{0.3}} && \\multicolumn{{3}}{{c}}{{0.5}} \\\\    \n",
    "        \\textbf{{Metric}} & Bias & Std & MSE && Bias & Std & MSE && Bias & Std & MSE \\\\\n",
    "        \\textbf{{Estimators}} &        &        &        &&        &        &  &&        &        &     \\\\        \n",
    "        \\midrule\n",
    "    \"\"\"\n",
    "\n",
    "        # Add data rows for each estimator\n",
    "        for i, name in enumerate(estm_name):\n",
    "            # Get values for all p values\n",
    "            values = []\n",
    "            for p in p_list:\n",
    "                values.extend([\n",
    "                    data[r2][p]['bias'][i],\n",
    "                    data[r2][p]['std'][i],\n",
    "                    data[r2][p]['mse'][i]\n",
    "                ])\n",
    "            \n",
    "            # Format the row with double separators between p values\n",
    "            row = f\"    \\\\textbf{{{name}}} \"\n",
    "            for j, val in enumerate(values):\n",
    "                sep = \" && \" if (j) % 3 == 0 and j> 1 else \" & \"\n",
    "                row += f\"{sep}{val:.3f}\"\n",
    "            row += \" \\\\\\\\\"\n",
    "            latex_table += row + \"\\n\"\n",
    "\n",
    "        latex_table += r\"\"\"    \\bottomrule\n",
    "        \\end{tabular}\n",
    "    \\end{table}\n",
    "    \"\"\"\n",
    "        table_list.append(latex_table)\n",
    "    \n",
    "    \n",
    "    # Write    \n",
    "    filename = 'Tables/1cov_res{}_covwgt{}.tex'.format(res, cov_weight)\n",
    "    \n",
    "    with open(filename, 'w', encoding='utf-8') as f:\n",
    "        for table in table_list:\n",
    "            f.write(table + \"\\n\")\n",
    "\n",
    "    print(\"All tables generated successfully!\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# zero weight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All tables generated successfully!\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "# Parameters\n",
    "\n",
    "cov_weight = 0\n",
    "r2_list = [0, 1]  # Will generate two tables\n",
    "p_list = [0.1, 0.3, 0.5]\n",
    "estm_name = [\"Hájek\", \"CAE\", \"MII\", \"GNN\", \"AMII\"]\n",
    "\n",
    "for res in [5]:\n",
    "\n",
    "    table_list = []\n",
    "\n",
    "    # Initialize data storage\n",
    "    # We'll use dictionary comprehension for better readability\n",
    "    data = {\n",
    "        r2: {\n",
    "            p: {\n",
    "                'bias': [],\n",
    "                'std': [],\n",
    "                'mse': []\n",
    "            } for p in p_list\n",
    "        } for r2 in r2_list\n",
    "    }\n",
    "\n",
    "    # Load data for all combinations\n",
    "    for r2 in r2_list:\n",
    "        for p in p_list:\n",
    "            # Load estimator results\n",
    "            estm_list = torch.load(f\"result_ablation/estm_list_res{res}_p{p}_cov{cov_weight}_r2{r2}.pkl\")\n",
    "            \n",
    "            # Calculate metrics for each estimator\n",
    "            for estm in estm_list:\n",
    "                data[r2][p]['bias'].append(np.abs(np.mean(estm)))\n",
    "                data[r2][p]['std'].append(np.std(estm))\n",
    "                data[r2][p]['mse'].append(np.mean(estm)**2 + np.var(estm))\n",
    "\n",
    "    # Generate LaTeX tables - one per r2 value\n",
    "    for r2 in r2_list:\n",
    "        latex_table = fr\"\"\"\n",
    "    \\begin{{table}}[ht]\n",
    "        \\centering\n",
    "        \\caption{{Statistical performance without covariates ($r_2 = {r2}$, $\\gamma = {res}$)}}\n",
    "        \\begin{{tabular}}{{l ccc c ccc c ccc}}\n",
    "        \\toprule\n",
    "        ${{p}}$ & \\multicolumn{{3}}{{c}}{{0.1}} && \\multicolumn{{3}}{{c}}{{0.3}} && \\multicolumn{{3}}{{c}}{{0.5}} \\\\    \n",
    "        \\textbf{{Metric}} & Bias & Std & MSE && Bias & Std & MSE && Bias & Std & MSE \\\\\n",
    "        \\textbf{{Estimators}} &        &        &        &&        &        &  &&        &        &     \\\\        \n",
    "        \\midrule\n",
    "    \"\"\"\n",
    "\n",
    "        # Add data rows for each estimator\n",
    "        for i, name in enumerate(estm_name):\n",
    "            # Get values for all p values\n",
    "            values = []\n",
    "            for p in p_list:\n",
    "                values.extend([\n",
    "                    data[r2][p]['bias'][i],\n",
    "                    data[r2][p]['std'][i],\n",
    "                    data[r2][p]['mse'][i]\n",
    "                ])\n",
    "            \n",
    "            # Format the row with double separators between p values\n",
    "            row = f\"    \\\\textbf{{{name}}} \"\n",
    "            for j, val in enumerate(values):\n",
    "                sep = \" && \" if (j) % 3 == 0 and j> 1 else \" & \"\n",
    "                row += f\"{sep}{val:.3f}\"\n",
    "            row += \" \\\\\\\\\"\n",
    "            latex_table += row + \"\\n\"\n",
    "\n",
    "        latex_table += r\"\"\"    \\bottomrule\n",
    "        \\end{tabular}\n",
    "    \\end{table}\n",
    "    \"\"\"\n",
    "        table_list.append(latex_table)\n",
    "    \n",
    "    \n",
    "    # Write    \n",
    "    filename = 'Tables/0cov_res{}.tex'.format(res, cov_weight)\n",
    "    \n",
    "    with open(filename, 'w', encoding='utf-8') as f:\n",
    "        for table in table_list:\n",
    "            f.write(table + \"\\n\")\n",
    "\n",
    "    print(\"All tables generated successfully!\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# on boundary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All tables generated successfully!\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "# Parameters\n",
    "\n",
    "cov_weight = 0.5\n",
    "r2_list = [0, 1]  # Will generate two tables\n",
    "p_list = [0.1, 0.3, 0.5]\n",
    "estm_name = [\"Hájek\", \"CAE\", \"MII\", \"GNN\", \"AMII\"]\n",
    "\n",
    "for res in [5]:\n",
    "\n",
    "    table_list = []\n",
    "\n",
    "    # Initialize data storage\n",
    "    # We'll use dictionary comprehension for better readability\n",
    "    data = {\n",
    "        r2: {\n",
    "            p: {\n",
    "                'bias': [],\n",
    "                'std': [],\n",
    "                'mse': []\n",
    "            } for p in p_list\n",
    "        } for r2 in r2_list\n",
    "    }\n",
    "\n",
    "    # Load data for all combinations\n",
    "    for r2 in r2_list:\n",
    "        for p in p_list:\n",
    "            # Load estimator results\n",
    "            estm_list = torch.load(f\"result_ablation/estm_list_regbnd_res{res}_p{p}_cov{cov_weight}_r2{r2}.pkl\")\n",
    "            \n",
    "            # Calculate metrics for each estimator\n",
    "            for estm in estm_list:\n",
    "                data[r2][p]['bias'].append(np.abs(np.mean(estm)))\n",
    "                data[r2][p]['std'].append(np.std(estm))\n",
    "                data[r2][p]['mse'].append(np.mean(estm)**2 + np.var(estm))\n",
    "\n",
    "    # Generate LaTeX tables - one per r2 value\n",
    "    for r2 in r2_list:\n",
    "        latex_table = fr\"\"\"\n",
    "    \\begin{{table}}[ht]\n",
    "        \\centering\n",
    "        \\caption{{Statistical performance with regression on boundary ($r_2 = {r2}$, $\\gamma = {res}$)}}\n",
    "        \\begin{{tabular}}{{l ccc c ccc c ccc}}\n",
    "        \\toprule\n",
    "        ${{p}}$ & \\multicolumn{{3}}{{c}}{{0.1}} && \\multicolumn{{3}}{{c}}{{0.3}} && \\multicolumn{{3}}{{c}}{{0.5}} \\\\    \n",
    "        \\textbf{{Metric}} & Bias & Std & MSE && Bias & Std & MSE && Bias & Std & MSE \\\\\n",
    "        \\textbf{{Estimators}} &        &        &        &&        &        &  &&        &        &     \\\\        \n",
    "        \\midrule\n",
    "    \"\"\"\n",
    "\n",
    "        # Add data rows for each estimator\n",
    "        for i, name in enumerate(estm_name):\n",
    "            # Get values for all p values\n",
    "            values = []\n",
    "            for p in p_list:\n",
    "                values.extend([\n",
    "                    data[r2][p]['bias'][i],\n",
    "                    data[r2][p]['std'][i],\n",
    "                    data[r2][p]['mse'][i]\n",
    "                ])\n",
    "            \n",
    "            # Format the row with double separators between p values\n",
    "            row = f\"    \\\\textbf{{{name}}} \"\n",
    "            for j, val in enumerate(values):\n",
    "                sep = \" && \" if (j) % 3 == 0 and j> 1 else \" & \"\n",
    "                row += f\"{sep}{val:.3f}\"\n",
    "            row += \" \\\\\\\\\"\n",
    "            latex_table += row + \"\\n\"\n",
    "\n",
    "        latex_table += r\"\"\"    \\bottomrule\n",
    "        \\end{tabular}\n",
    "    \\end{table}\n",
    "    \"\"\"\n",
    "        table_list.append(latex_table)\n",
    "    \n",
    "    \n",
    "    # Write    \n",
    "    filename = 'Tables/bnd_res{}.tex'.format(res, cov_weight)\n",
    "    \n",
    "    with open(filename, 'w', encoding='utf-8') as f:\n",
    "        for table in table_list:\n",
    "            f.write(table + \"\\n\")\n",
    "\n",
    "    print(\"All tables generated successfully!\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# USF DATASET\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All tables generated successfully!\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "# Parameters\n",
    "\n",
    "cov_weight = 0.5\n",
    "r2_list = [0, 1]  # Will generate two tables\n",
    "p_list = [0.1, 0.3, 0.5]\n",
    "estm_name = [\"Hájek\", \"CAE\", \"MII\", \"GNN\", \"AMII\"]\n",
    "\n",
    "for res in [5]:\n",
    "\n",
    "    table_list = []\n",
    "\n",
    "    # Initialize data storage\n",
    "    # We'll use dictionary comprehension for better readability\n",
    "    data = {\n",
    "        r2: {\n",
    "            p: {\n",
    "                'bias': [],\n",
    "                'std': [],\n",
    "                'mse': []\n",
    "            } for p in p_list\n",
    "        } for r2 in r2_list\n",
    "    }\n",
    "\n",
    "    # Load data for all combinations\n",
    "    for r2 in r2_list:\n",
    "        for p in p_list:\n",
    "            # Load estimator results\n",
    "            estm_list = torch.load(f\"result/estm_list_USF_res{res}_p{p}_cov{cov_weight}_r2{r2}.pkl\")\n",
    "            \n",
    "            # Calculate metrics for each estimator\n",
    "            for estm in estm_list:\n",
    "                data[r2][p]['bias'].append(np.abs(np.mean(estm)))\n",
    "                data[r2][p]['std'].append(np.std(estm))\n",
    "                data[r2][p]['mse'].append(np.mean(estm)**2 + np.var(estm))\n",
    "\n",
    "    # Generate LaTeX tables - one per r2 value\n",
    "    for r2 in r2_list:\n",
    "        latex_table = fr\"\"\"\n",
    "    \\begin{{table}}[ht]\n",
    "        \\centering\n",
    "        \\caption{{Statistical performance with regression on boundary ($r_2 = {r2}$, $\\gamma = {res}$)}}\n",
    "        \\begin{{tabular}}{{l ccc c ccc c ccc}}\n",
    "        \\toprule\n",
    "        ${{p}}$ & \\multicolumn{{3}}{{c}}{{0.1}} && \\multicolumn{{3}}{{c}}{{0.3}} && \\multicolumn{{3}}{{c}}{{0.5}} \\\\    \n",
    "        \\textbf{{Metric}} & Bias & Std & MSE && Bias & Std & MSE && Bias & Std & MSE \\\\\n",
    "        \\textbf{{Estimators}} &        &        &        &&        &        &  &&        &        &     \\\\        \n",
    "        \\midrule\n",
    "    \"\"\"\n",
    "\n",
    "        # Add data rows for each estimator\n",
    "        for i, name in enumerate(estm_name):\n",
    "            # Get values for all p values\n",
    "            values = []\n",
    "            for p in p_list:\n",
    "                values.extend([\n",
    "                    data[r2][p]['bias'][i],\n",
    "                    data[r2][p]['std'][i],\n",
    "                    data[r2][p]['mse'][i]\n",
    "                ])\n",
    "            \n",
    "            # Format the row with double separators between p values\n",
    "            row = f\"    \\\\textbf{{{name}}} \"\n",
    "            for j, val in enumerate(values):\n",
    "                sep = \" && \" if (j) % 3 == 0 and j> 1 else \" & \"\n",
    "                row += f\"{sep}{val:.3f}\"\n",
    "            row += \" \\\\\\\\\"\n",
    "            latex_table += row + \"\\n\"\n",
    "\n",
    "        latex_table += r\"\"\"    \\bottomrule\n",
    "        \\end{tabular}\n",
    "    \\end{table}\n",
    "    \"\"\"\n",
    "        table_list.append(latex_table)\n",
    "    \n",
    "    \n",
    "    # Write    \n",
    "    filename = 'Tables/USF_res{}.tex'.format(res, cov_weight)\n",
    "    \n",
    "    with open(filename, 'w', encoding='utf-8') as f:\n",
    "        for table in table_list:\n",
    "            f.write(table + \"\\n\")\n",
    "\n",
    "    print(\"All tables generated successfully!\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
