{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "8698c58d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Method: AdaRHD, Learning Rate: 5.0, Ratio: 0.05\n",
      "Mean time for 50% val acc: 287.20 ± 93.61 seconds\n",
      "Mean time for 70% val acc: 464.79 ± 124.76 seconds\n",
      "Mean time for 85% val acc: 1217.06 ± 635.57 seconds\n",
      "Method: AdaRHD, Learning Rate: 1.0, Ratio: 0.05\n",
      "Mean time for 50% val acc: 131.84 ± 18.76 seconds\n",
      "Mean time for 70% val acc: 191.51 ± 34.15 seconds\n",
      "Mean time for 85% val acc: 245.63 ± 72.42 seconds\n",
      "Method: AdaRHD, Learning Rate: 0.5, Ratio: 0.05\n",
      "Mean time for 50% val acc: 118.09 ± 19.91 seconds\n",
      "Mean time for 70% val acc: 169.79 ± 28.59 seconds\n",
      "Mean time for 85% val acc: 241.54 ± 33.09 seconds\n",
      "Method: AdaRHD, Learning Rate: 0.1, Ratio: 0.05\n",
      "Mean time for 50% val acc: 217.32 ± 33.96 seconds\n",
      "Mean time for 70% val acc: 312.58 ± 33.66 seconds\n",
      "Mean time for 85% val acc: 427.84 ± 53.40 seconds\n",
      "Method: AdaRHD, Learning Rate: 0.05, Ratio: 0.05\n",
      "Mean time for 50% val acc: 251.47 ± 36.27 seconds\n",
      "Mean time for 70% val acc: 415.51 ± 49.75 seconds\n",
      "Mean time for 85% val acc: 633.46 ± 96.54 seconds\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "\n",
    "ratio = 0.05\n",
    "method = 'AdaRHD'\n",
    "methodopt = 'cg'\n",
    "AdaRHD_cg_val50times_means = []\n",
    "AdaRHD_cg_val50times_stds = []\n",
    "AdaRHD_cg_val70times_means = []\n",
    "AdaRHD_cg_val70times_stds = []\n",
    "AdaRHD_cg_val85times_means = []\n",
    "AdaRHD_cg_val85times_stds = []\n",
    "for lr in [5.0, 1.0, 0.5, 0.1, 0.05]:\n",
    "    with open(f'../results/hyrep_spd_{method}_{methodopt}_lr{lr}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "        data = pickle.load(handle)\n",
    "\n",
    "    print(f\"Method: {method}, Learning Rate: {lr}, Ratio: {ratio}\")\n",
    "    val50times = data['val50_time']\n",
    "    val50times = np.array([t.item() for t in val50times])\n",
    "    val50time_mean = np.mean(val50times)\n",
    "    val50time_std = np.std(val50times)\n",
    "    AdaRHD_cg_val50times_means.append(val50time_mean)\n",
    "    AdaRHD_cg_val50times_stds.append(val50time_std)\n",
    "\n",
    "    print(f\"Mean time for 50% val acc: {val50time_mean:.2f} ± {val50time_std:.2f} seconds\")\n",
    "\n",
    "    val70times = data['val70_time']\n",
    "    val70times = np.array([t.item() for t in val70times])\n",
    "    val70time_mean = np.mean(val70times)\n",
    "    val70time_std = np.std(val70times)\n",
    "    AdaRHD_cg_val70times_means.append(val70time_mean)\n",
    "    AdaRHD_cg_val70times_stds.append(val70time_std)\n",
    "\n",
    "    print(f\"Mean time for 70% val acc: {val70time_mean:.2f} ± {val70time_std:.2f} seconds\")\n",
    "\n",
    "    val85times = data['val85_time']\n",
    "    val85times = np.array([t.item() for t in val85times])\n",
    "    val85time_mean = np.mean(val85times)\n",
    "    val85time_std = np.std(val85times)\n",
    "    AdaRHD_cg_val85times_means.append(val85time_mean)\n",
    "    AdaRHD_cg_val85times_stds.append(val85time_std)\n",
    "\n",
    "    print(f\"Mean time for 85% val acc: {val85time_mean:.2f} ± {val85time_std:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "59042260",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Method: AdaRHD, Learning Rate: 5.0, Ratio: 0.05\n",
      "Mean time for 50% val acc: 432.66 ± 157.76 seconds\n",
      "Mean time for 70% val acc: 690.62 ± 136.52 seconds\n",
      "Mean time for 85% val acc: 1488.26 ± 426.67 seconds\n",
      "Method: AdaRHD, Learning Rate: 1.0, Ratio: 0.05\n",
      "Mean time for 50% val acc: 200.26 ± 31.21 seconds\n",
      "Mean time for 70% val acc: 317.31 ± 68.92 seconds\n",
      "Mean time for 85% val acc: 421.99 ± 88.31 seconds\n",
      "Method: AdaRHD, Learning Rate: 0.5, Ratio: 0.05\n",
      "Mean time for 50% val acc: 192.51 ± 22.86 seconds\n",
      "Mean time for 70% val acc: 291.83 ± 54.21 seconds\n",
      "Mean time for 85% val acc: 477.49 ± 120.17 seconds\n",
      "Method: AdaRHD, Learning Rate: 0.1, Ratio: 0.05\n",
      "Mean time for 50% val acc: 297.90 ± 42.60 seconds\n",
      "Mean time for 70% val acc: 447.60 ± 53.50 seconds\n",
      "Mean time for 85% val acc: 546.18 ± 66.68 seconds\n",
      "Method: AdaRHD, Learning Rate: 0.05, Ratio: 0.05\n",
      "Mean time for 50% val acc: 358.25 ± 32.89 seconds\n",
      "Mean time for 70% val acc: 504.80 ± 15.58 seconds\n",
      "Mean time for 85% val acc: 648.86 ± 42.91 seconds\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "\n",
    "ratio = 0.05\n",
    "method = 'AdaRHD'\n",
    "methodopt = 'gd'\n",
    "AdaRHD_gd_val50times_means = []\n",
    "AdaRHD_gd_val50times_stds = []\n",
    "AdaRHD_gd_val70times_means = []\n",
    "AdaRHD_gd_val70times_stds = []\n",
    "AdaRHD_gd_val85times_means = []\n",
    "AdaRHD_gd_val85times_stds = []\n",
    "for lr in [5.0, 1.0, 0.5, 0.1, 0.05]:\n",
    "    with open(f'../results/hyrep_spd_{method}_{methodopt}_lr{lr}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "        data = pickle.load(handle)\n",
    "\n",
    "    print(f\"Method: {method}, Learning Rate: {lr}, Ratio: {ratio}\")\n",
    "    val50times = data['val50_time']\n",
    "    val50times = np.array([t.item() for t in val50times])\n",
    "    val50time_mean = np.mean(val50times)\n",
    "    val50time_std = np.std(val50times)\n",
    "    AdaRHD_gd_val50times_means.append(val50time_mean)\n",
    "    AdaRHD_gd_val50times_stds.append(val50time_std)\n",
    "\n",
    "    print(f\"Mean time for 50% val acc: {val50time_mean:.2f} ± {val50time_std:.2f} seconds\")\n",
    "\n",
    "    val70times = data['val70_time']\n",
    "    val70times = np.array([t.item() for t in val70times])\n",
    "    val70time_mean = np.mean(val70times)\n",
    "    val70time_std = np.std(val70times)\n",
    "    AdaRHD_gd_val70times_means.append(val70time_mean)\n",
    "    AdaRHD_gd_val70times_stds.append(val70time_std)\n",
    "\n",
    "    print(f\"Mean time for 70% val acc: {val70time_mean:.2f} ± {val70time_std:.2f} seconds\")\n",
    "\n",
    "    val85times = data['val85_time']\n",
    "    val85times = np.array([t.item() for t in val85times])\n",
    "    val85time_mean = np.mean(val85times)\n",
    "    val85time_std = np.std(val85times)\n",
    "    AdaRHD_gd_val85times_means.append(val85time_mean)\n",
    "    AdaRHD_gd_val85times_stds.append(val85time_std)\n",
    "\n",
    "    print(f\"Mean time for 85% val acc: {val85time_mean:.2f} ± {val85time_std:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3529649b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Method: RHGD, Learning Rate: 5, Ratio: 0.05\n",
      "All values are None.\n",
      "All values are None.\n",
      "All values are None.\n",
      "Method: RHGD, Learning Rate: 1, Ratio: 0.05\n",
      "All values are None.\n",
      "All values are None.\n",
      "All values are None.\n",
      "Method: RHGD, Learning Rate: 0.5, Ratio: 0.05\n",
      "All values are None.\n",
      "All values are None.\n",
      "All values are None.\n",
      "Method: RHGD, Learning Rate: 0.1, Ratio: 0.05\n",
      "Mean time for 50% val acc: 171.97 ± 78.36 seconds\n",
      "Mean time for 70% val acc: 370.69 ± 68.61 seconds\n",
      "Mean time for 85% val acc: 808.48 ± 146.57 seconds\n",
      "Method: RHGD, Learning Rate: 0.05, Ratio: 0.05\n",
      "Mean time for 50% val acc: 137.88 ± 136.10 seconds\n",
      "Mean time for 70% val acc: 715.91 ± 104.62 seconds\n",
      "Mean time for 85% val acc: 1510.09 ± 363.41 seconds\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "\n",
    "ratio = 0.05\n",
    "method = 'RHGD'\n",
    "methodopt = '50'\n",
    "RHGD_50_val50times_means = []\n",
    "RHGD_50_val50times_stds = []\n",
    "RHGD_50_val70times_means = []\n",
    "RHGD_50_val70times_stds = []\n",
    "RHGD_50_val85times_means = []\n",
    "RHGD_50_val85times_stds = []\n",
    "for lr in [5,1,0.5,0.1,0.05]:\n",
    "    print(f\"Method: {method}, Learning Rate: {lr}, Ratio: {ratio}\")\n",
    "    with open(f'../results/hyrep_spd_{method}_lr{lr}_loweriter{methodopt}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "        data = pickle.load(handle)\n",
    "\n",
    "    val50times = data['val50_time']\n",
    "    if all(x is None for x in val50times):\n",
    "        print(\"All values are None.\")\n",
    "        RHGD_50_val50times_means.append(None)\n",
    "        RHGD_50_val50times_stds.append(None)\n",
    "    else:\n",
    "        non_none_values = [x.item() for x in val50times if x is not None]\n",
    "        if len(non_none_values) < len(val50times):\n",
    "            print(f\"50% failed number of times: {len(val50times) - len(non_none_values)}\")\n",
    "        # Replace None values with mean of non-None values\n",
    "        mean_value = sum(non_none_values) / len(non_none_values)\n",
    "        RHGD_50_val50times_means.append(mean_value)\n",
    "        std_value = np.std(non_none_values)\n",
    "        RHGD_50_val50times_stds.append(std_value)\n",
    "        print(f\"Mean time for 50% val acc: {mean_value:.2f} ± {std_value:.2f} seconds\")\n",
    "    \n",
    "    val70times = data['val70_time']\n",
    "    if all(x is None for x in val70times):\n",
    "        print(\"All values are None.\")\n",
    "        RHGD_50_val70times_means.append(None)\n",
    "        RHGD_50_val70times_stds.append(None)\n",
    "    else:\n",
    "        non_none_values = [x.item() for x in val70times if x is not None]\n",
    "        if len(non_none_values) < len(val70times):\n",
    "            print(f\"70% failed number of times: {len(val70times) - len(non_none_values)}\")\n",
    "        # Replace None values with mean of non-None values\n",
    "        mean_value = sum(non_none_values) / len(non_none_values)\n",
    "        RHGD_50_val70times_means.append(mean_value)\n",
    "        std_value = np.std(non_none_values)\n",
    "        RHGD_50_val70times_stds.append(std_value)\n",
    "        print(f\"Mean time for 70% val acc: {mean_value:.2f} ± {std_value:.2f} seconds\")\n",
    "\n",
    "            \n",
    "    val85times = data['val85_time']\n",
    "    if all(x is None for x in val85times):\n",
    "        print(\"All values are None.\")\n",
    "        RHGD_50_val85times_means.append(None)\n",
    "        RHGD_50_val85times_stds.append(None)\n",
    "    else:\n",
    "        non_none_values = [x.item() for x in val85times if x is not None]\n",
    "        if len(non_none_values) < len(val85times):\n",
    "            print(f\"85% failed number of times: {len(val85times) - len(non_none_values)}\")\n",
    "        # Replace None values with mean of non-None values\n",
    "        mean_value = sum(non_none_values) / len(non_none_values)\n",
    "        RHGD_50_val85times_means.append(mean_value)\n",
    "        std_value = np.std(non_none_values)\n",
    "        RHGD_50_val85times_stds.append(std_value)\n",
    "        print(f\"Mean time for 85% val acc: {mean_value:.2f} ± {std_value:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ce723834",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Method: RHGD, Learning Rate: 5, Ratio: 0.05\n",
      "All values are None.\n",
      "All values are None.\n",
      "All values are None.\n",
      "Method: RHGD, Learning Rate: 1, Ratio: 0.05\n",
      "All values are None.\n",
      "All values are None.\n",
      "All values are None.\n",
      "Method: RHGD, Learning Rate: 0.5, Ratio: 0.05\n",
      "All values are None.\n",
      "All values are None.\n",
      "All values are None.\n",
      "Method: RHGD, Learning Rate: 0.1, Ratio: 0.05\n",
      "Mean time for 50% val acc: 36.01 ± 12.37 seconds\n",
      "Mean time for 70% val acc: 168.47 ± 120.86 seconds\n",
      "Mean time for 85% val acc: 540.46 ± 88.54 seconds\n",
      "Method: RHGD, Learning Rate: 0.05, Ratio: 0.05\n",
      "Mean time for 50% val acc: 41.36 ± 6.88 seconds\n",
      "Mean time for 70% val acc: 179.11 ± 157.76 seconds\n",
      "Mean time for 85% val acc: 1067.92 ± 122.98 seconds\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "\n",
    "ratio = 0.05\n",
    "method = 'RHGD'\n",
    "methodopt = '20'\n",
    "RHGD_20_val50times_means = []\n",
    "RHGD_20_val50times_stds = []\n",
    "RHGD_20_val70times_means = []\n",
    "RHGD_20_val70times_stds = []\n",
    "RHGD_20_val85times_means = []\n",
    "RHGD_20_val85times_stds = []\n",
    "for lr in [5,1,0.5,0.1,0.05]:\n",
    "    print(f\"Method: {method}, Learning Rate: {lr}, Ratio: {ratio}\")\n",
    "    with open(f'../results/hyrep_spd_{method}_lr{lr}_loweriter{methodopt}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "        data = pickle.load(handle)\n",
    "\n",
    "    val50times = data['val50_time']\n",
    "    if all(x is None for x in val50times):\n",
    "        print(\"All values are None.\")\n",
    "        RHGD_20_val50times_means.append(None)\n",
    "        RHGD_20_val50times_stds.append(None)\n",
    "    else:\n",
    "        non_none_values = [x.item() for x in val50times if x is not None]\n",
    "        if len(non_none_values) < len(val50times):\n",
    "            print(f\"50% failed number of times: {len(val50times) - len(non_none_values)}\")\n",
    "        # Replace None values with mean of non-None values\n",
    "        mean_value = sum(non_none_values) / len(non_none_values)\n",
    "        RHGD_20_val50times_means.append(mean_value)\n",
    "        std_value = np.std(non_none_values)\n",
    "        RHGD_20_val50times_stds.append(std_value)\n",
    "        print(f\"Mean time for 50% val acc: {mean_value:.2f} ± {std_value:.2f} seconds\")\n",
    "    \n",
    "    val70times = data['val70_time']\n",
    "    if all(x is None for x in val70times):\n",
    "        print(\"All values are None.\")\n",
    "        RHGD_20_val70times_means.append(None)\n",
    "        RHGD_20_val70times_stds.append(None)\n",
    "    else:\n",
    "        non_none_values = [x.item() for x in val70times if x is not None]\n",
    "        if len(non_none_values) < len(val70times):\n",
    "            print(f\"70% failed number of times: {len(val70times) - len(non_none_values)}\")\n",
    "        # Replace None values with mean of non-None values\n",
    "        mean_value = sum(non_none_values) / len(non_none_values)\n",
    "        RHGD_20_val70times_means.append(mean_value)\n",
    "        std_value = np.std(non_none_values)\n",
    "        RHGD_20_val70times_stds.append(std_value)\n",
    "        print(f\"Mean time for 70% val acc: {mean_value:.2f} ± {std_value:.2f} seconds\")\n",
    "\n",
    "            \n",
    "    val85times = data['val85_time']\n",
    "    if all(x is None for x in val85times):\n",
    "        print(\"All values are None.\")\n",
    "        RHGD_20_val85times_means.append(None)\n",
    "        RHGD_20_val85times_stds.append(None)\n",
    "    else:\n",
    "        non_none_values = [x.item() for x in val85times if x is not None]\n",
    "        if len(non_none_values) < len(val85times):\n",
    "            print(f\"85% failed number of times: {len(val85times) - len(non_none_values)}\")\n",
    "        # Replace None values with mean of non-None values\n",
    "        mean_value = sum(non_none_values) / len(non_none_values)\n",
    "        RHGD_20_val85times_means.append(mean_value)\n",
    "        std_value = np.std(non_none_values)\n",
    "        RHGD_20_val85times_stds.append(std_value)\n",
    "        print(f\"Mean time for 85% val acc: {mean_value:.2f} ± {std_value:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "389d62d5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{table}[h]\n",
      "\\scriptsize\n",
      "\\setlength{\\tabcolsep}{0.5pt}\n",
      "\\centering\n",
      "\\caption{Time to reach validation accuracy thresholds (in seconds)}\n",
      "\\begin{tabular}{c|ccc|ccc|ccc|ccc}\n",
      "\\hline\n",
      " & \\multicolumn{3}{c|}{AdaRHD-CG} & \\multicolumn{3}{c|}{AdaRHD-GD} & \\multicolumn{3}{c|}{RHGD-50} & \\multicolumn{3}{c}{RHGD-20} \\\\\n",
      "Step Size & 50\\% & 70\\% & 85\\% & 50\\% & 70\\% & 85\\% & 50\\% & 70\\% & 85\\% & 50\\% & 70\\% & 85\\% \\\\\n",
      "\\hline\n",
      "\\multirow{2}{*}{5.0} & \\textbf{287.20} & \\textbf{464.79} & \\textbf{1217.06} & 432.66 & 690.62 & 1488.26 & / & / & / & / & / & /  \\\\\n",
      "  & $(\\textbf{93.61})$ & $(\\textbf{124.76})$ & $(\\textbf{635.57})$ & $(157.76)$ & $(136.52)$ & $(426.67)$ & / & / & / & / & / & /  \\\\\n",
      "\\multirow{2}{*}{1.0} & \\textbf{131.84} & \\textbf{191.51} & \\textbf{245.63} & 200.26 & 317.31 & 421.99 & / & / & / & / & / & /  \\\\\n",
      "  & $(\\textbf{18.76})$ & $(\\textbf{34.15})$ & $(\\textbf{72.42})$ & $(31.21)$ & $(68.92)$ & $(88.31)$ & / & / & / & / & / & /  \\\\\n",
      "\\multirow{2}{*}{0.5} & \\textbf{118.09} & \\textbf{169.79} & \\textbf{241.54} & 192.51 & 291.83 & 477.49 & / & / & / & / & / & /  \\\\\n",
      "  & $(\\textbf{19.91})$ & $(\\textbf{28.59})$ & $(\\textbf{33.09})$ & $(22.86)$ & $(54.21)$ & $(120.17)$ & / & / & / & / & / & /  \\\\\n",
      "\\multirow{2}{*}{0.1} & \\textbf{217.32} & \\textbf{312.58} & \\textbf{427.84} & 297.90 & 447.60 & 546.18 & 171.97 & 370.69 & 808.48 & 36.01 & 168.47 & 540.46 \\\\\n",
      "  & $(\\textbf{33.96})$ & $(\\textbf{33.66})$ & $(\\textbf{53.40})$ & $(42.60)$ & $(53.50)$ & $(66.68)$ & $(78.36)$ & $(68.61)$ & $(146.57)$ & $(12.37)$ & $(120.86)$ & $(88.54)$ \\\\\n",
      "\\multirow{2}{*}{0.05} & \\textbf{251.47} & \\textbf{415.51} & \\textbf{633.46} & 358.25 & 504.80 & 648.86 & 137.88 & 715.91 & 1510.09 & 41.36 & 179.11 & 1067.92 \\\\\n",
      "  & $(\\textbf{36.27})$ & $(\\textbf{49.75})$ & $(\\textbf{96.54})$ & $(32.89)$ & $(15.58)$ & $(42.91)$ & $(136.10)$ & $(104.62)$ & $(363.41)$ & $(6.88)$ & $(157.76)$ & $(122.98)$ \\\\\n",
      "\\hline\n",
      "\\end{tabular}\n",
      "\\label{tab:robust valtimes}\n",
      "\\end{table}\n"
     ]
    }
   ],
   "source": [
    "# Learning rates used\n",
    "learning_rates2 = [5.0, 1.0, 0.5, 0.1, 0.05]\n",
    "\n",
    "# Create LaTeX table header\n",
    "latex_code = \"\\\\begin{table}[h]\\n\\\\scriptsize\\n\\\\setlength{\\\\tabcolsep}{0.5pt}\\n\\\\centering\\n\\\\caption{Time to reach validation accuracy thresholds (in seconds)}\\n\\\\begin{tabular}{c|ccc|ccc|ccc|ccc}\\n\\\\hline\\n\"\n",
    "latex_code += \" & \\\\multicolumn{3}{c|}{AdaRHD-CG} & \\\\multicolumn{3}{c|}{AdaRHD-GD} & \\\\multicolumn{3}{c|}{RHGD-50} & \\\\multicolumn{3}{c}{RHGD-20} \\\\\\\\\\n\"\n",
    "latex_code += \"Step Size & 50\\\\% & 70\\\\% & 85\\\\% & 50\\\\% & 70\\\\% & 85\\\\% & 50\\\\% & 70\\\\% & 85\\\\% & 50\\\\% & 70\\\\% & 85\\\\% \\\\\\\\\\n\\\\hline\\n\"\n",
    "\n",
    "# Add data rows\n",
    "for i, lr in enumerate(learning_rates2):\n",
    "    row = f\"\\\\multirow{{2}}{{*}}{{{lr}}} & \"\n",
    "    # AdaRHD data\n",
    "    row += f\"\\\\textbf{{{AdaRHD_cg_val50times_means[i]:.2f}}} & \\\\textbf{{{AdaRHD_cg_val70times_means[i]:.2f}}} & \\\\textbf{{{AdaRHD_cg_val85times_means[i]:.2f}}} & \"\n",
    "    row += f\"{AdaRHD_gd_val50times_means[i]:.2f} & {AdaRHD_gd_val70times_means[i]:.2f} & {AdaRHD_gd_val85times_means[i]:.2f} & \"\n",
    "    # RHGD data\n",
    "    if RHGD_50_val50times_means[i] is None:\n",
    "        row += \"/ & \"\n",
    "    else:\n",
    "        row += f\"{RHGD_50_val50times_means[i]:.2f} & \"\n",
    "    \n",
    "    if RHGD_50_val70times_means[i] is None:\n",
    "        row += \"/ & \"\n",
    "    else:\n",
    "        row += f\"{RHGD_50_val70times_means[i]:.2f} & \"\n",
    "    \n",
    "    if RHGD_50_val85times_means[i] is None:\n",
    "        row += \"/ & \"\n",
    "    else:\n",
    "        row += f\"{RHGD_50_val85times_means[i]:.2f} & \"\n",
    "\n",
    "    if RHGD_20_val50times_means[i] is None:\n",
    "        row += \"/ & \"\n",
    "    else:\n",
    "        row += f\"{RHGD_20_val50times_means[i]:.2f} & \"\n",
    "\n",
    "    if RHGD_20_val70times_means[i] is None:\n",
    "        row += \"/ & \"\n",
    "    else:\n",
    "        row += f\"{RHGD_20_val70times_means[i]:.2f} & \"\n",
    "\n",
    "    if RHGD_20_val85times_means[i] is None:\n",
    "        row += \"/ \"\n",
    "    else:\n",
    "        row += f\"{RHGD_20_val85times_means[i]:.2f}\"\n",
    "    \n",
    "    row += \" \\\\\\\\\\n\"\n",
    "    row += \"  & \"\n",
    "    # AdaRHD data\n",
    "    row += f\"$(\\\\textbf{{{AdaRHD_cg_val50times_stds[i]:.2f}}})$ & $(\\\\textbf{{{AdaRHD_cg_val70times_stds[i]:.2f}}})$ & $(\\\\textbf{{{AdaRHD_cg_val85times_stds[i]:.2f}}})$ & \"\n",
    "    row += f\"$({AdaRHD_gd_val50times_stds[i]:.2f})$ & $({AdaRHD_gd_val70times_stds[i]:.2f})$ & $({AdaRHD_gd_val85times_stds[i]:.2f})$ & \"\n",
    "    # RHGD data\n",
    "    if RHGD_50_val50times_stds[i] is None:\n",
    "        row += \"/ & \"\n",
    "    else:\n",
    "        row += f\"$({RHGD_50_val50times_stds[i]:.2f})$ & \"\n",
    "    \n",
    "    if RHGD_50_val70times_stds[i] is None:\n",
    "        row += \"/ & \"\n",
    "    else:\n",
    "        row += f\"$({RHGD_50_val70times_stds[i]:.2f})$ & \"\n",
    "\n",
    "    if RHGD_50_val85times_stds[i] is None:\n",
    "        row += \"/ & \"\n",
    "    else:\n",
    "        row += f\"$({RHGD_50_val85times_stds[i]:.2f})$ & \"\n",
    "\n",
    "    if RHGD_20_val50times_stds[i] is None:\n",
    "        row += \"/ & \"\n",
    "    else:\n",
    "        row += f\"$({RHGD_20_val50times_stds[i]:.2f})$ & \"\n",
    "\n",
    "    if RHGD_20_val70times_stds[i] is None:\n",
    "        row += \"/ & \"\n",
    "    else:\n",
    "        row += f\"$({RHGD_20_val70times_stds[i]:.2f})$ & \"\n",
    "\n",
    "    if RHGD_20_val85times_stds[i] is None:\n",
    "        row += \"/ \"\n",
    "    else:\n",
    "        row += f\"$({RHGD_20_val85times_stds[i]:.2f})$\"\n",
    "    \n",
    "    row += \" \\\\\\\\\\n\"\n",
    "    latex_code += row\n",
    "\n",
    "# Add table footer\n",
    "latex_code += \"\\\\hline\\n\\\\end{tabular}\\n\\\\label{tab:robust valtimes}\\n\\\\end{table}\"\n",
    "\n",
    "print(latex_code)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
