{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean time for 50% val acc: 2511.13 ± 233.16 seconds\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "\n",
    "ratio = 0.25\n",
    "with open(f'../results/hyrep_spd_AdaRHD_cg_lr0.1data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "val50times1 = data['val50_time']\n",
    "val50times1 = np.array([t.item() for t in val50times1])\n",
    "val50time_mean1 = np.mean(val50times1)\n",
    "val50time_std1 = np.std(val50times1)\n",
    "\n",
    "print(f\"Mean time for 50% val acc: {val50time_mean1:.2f} ± {val50time_std1:.2f} seconds\")\n",
    "\n",
    "# val70times1 = data['val70_time']\n",
    "# val70times1 = np.array([t.item() for t in val70times1])\n",
    "# val70time_mean1 = np.mean(val70times1)\n",
    "# val70time_std1 = np.std(val70times1)\n",
    "\n",
    "# print(f\"Mean time for 50% val acc: {val70time_mean1:.2f} ± {val70time_std1:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean time for 50% val acc: 3408.80 ± 508.51 seconds\n"
     ]
    }
   ],
   "source": [
    "with open(f'../results/hyrep_spd_AdaRHD_gd_lr0.1data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "val50times2 = data['val50_time']\n",
    "val50times2 = np.array([t.item() for t in val50times2])\n",
    "val50time_mean2 = np.mean(val50times2)\n",
    "val50time_std2 = np.std(val50times2)\n",
    "\n",
    "print(f\"Mean time for 50% val acc: {val50time_mean2:.2f} ± {val50time_std2:.2f} seconds\")\n",
    "\n",
    "# val70times2 = data['val70_time']\n",
    "# val70times2 = np.array([t.item() for t in val70times2])\n",
    "# val70time_mean2 = np.mean(val70times2)\n",
    "# val70time_std2 = np.std(val70times2)\n",
    "\n",
    "# print(f\"Mean time for 70% val acc: {val70time_mean2:.2f} ± {val70time_std2:.2f} seconds\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean time for 50% val acc: 3944.26 ± 589.55 seconds\n"
     ]
    }
   ],
   "source": [
    "with open(f'../results/hyrep_spd_RHGD_lr0.1_loweriter50data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "\n",
    "val50times3 = data['val50_time']\n",
    "val50times3 = np.array([t.item() for t in val50times3])\n",
    "val50time_mean3 = np.mean(val50times3)\n",
    "val50time_std3 = np.std(val50times3)\n",
    "\n",
    "print(f\"Mean time for 50% val acc: {val50time_mean3:.2f} ± {val50time_std3:.2f} seconds\")\n",
    "\n",
    "# val70times3 = data['val70_time']\n",
    "# val70times3 = np.array([t.item() for t in val70times3])\n",
    "# val70time_mean3 = np.mean(val70times3)\n",
    "# val70time_std3 = np.std(val70times3)\n",
    "\n",
    "# print(f\"Mean time for 70% val acc: {val70time_mean3:.2f} ± {val70time_std3:.2f} seconds\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean time for 50% val acc: 2598.87 ± 645.08 seconds\n"
     ]
    }
   ],
   "source": [
    "with open(f'../results/hyrep_spd_RHGD_lr0.1_loweriter20data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "val50times4 = data['val50_time']\n",
    "val50times4 = np.array([t.item() for t in val50times4])\n",
    "val50time_mean4 = np.mean(val50times4)\n",
    "val50time_std4 = np.std(val50times4)\n",
    "\n",
    "print(f\"Mean time for 50% val acc: {val50time_mean4:.2f} ± {val50time_std4:.2f} seconds\")\n",
    "\n",
    "# val70times4 = data['val70_time']\n",
    "# val70times4 = np.array([t.item() for t in val70times4])\n",
    "# val70time_mean4 = np.mean(val70times4)\n",
    "# val70time_std4 = np.std(val70times4)\n",
    "\n",
    "# print(f\"Mean time for 70% val acc: {val70time_mean4:.2f} ± {val70time_std4:.2f} seconds\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{|l|c|c|c|c|}\n",
      "\\hline\n",
      "Metric & AdaRHD-CG & AdaRHD-GD & RHGD-50 & RHGD-20 \\\\\n",
      "\\hline\n",
      "Time to 50\\% & $2511.13 \\pm 233.16$ & $3408.80 \\pm 508.51$ & $3944.26 \\pm 589.55$ & $2598.87 \\pm 645.08$\\\\\n",
      "\\hline\n",
      "\\end{tabular}\n"
     ]
    }
   ],
   "source": [
    "# Define method names\n",
    "methods = [\"AdaRHD-CG\", \"AdaRHD-GD\", \"RHGD-50\", \"RHGD-20\"]\n",
    "\n",
    "# Collect values\n",
    "val50_means = [val50time_mean1, val50time_mean2, val50time_mean3, val50time_mean4]\n",
    "val50_stds = [val50time_std1, val50time_std2, val50time_std3, val50time_std4]\n",
    "# val70_means = [val70time_mean1, val70time_mean2, val70time_mean3, val70time_mean4]\n",
    "# val70_stds = [val70time_std1, val70time_std2, val70time_std3, val70time_std4]\n",
    "\n",
    "# Generate LaTeX table\n",
    "print(r\"\\begin{tabular}{|l|c|c|c|c|}\")\n",
    "print(r\"\\hline\")\n",
    "print(f\"Metric & {methods[0]} & {methods[1]} & {methods[2]} & {methods[3]} \\\\\\\\\")\n",
    "print(r\"\\hline\")\n",
    "\n",
    "# Print row for 50% validation accuracy time\n",
    "val50_row = \"Time to 50\\\\% & \"\n",
    "for i in range(4):\n",
    "  val50_row += f\"${val50_means[i]:.2f} \\\\pm {val50_stds[i]:.2f}$ & \"\n",
    "val50_row = val50_row[:-3] + \"\\\\\\\\\"  # Replace last \"& \" with \"\\\\\"\n",
    "print(val50_row)\n",
    "print(r\"\\hline\")\n",
    "\n",
    "# Print row for 70% validation accuracy time\n",
    "# val70_row = \"Time to 70\\\\% & \"\n",
    "# for i in range(4):\n",
    "#   val70_row += f\"${val70_means[i]:.2f} \\\\pm {val70_stds[i]:.2f}$ & \"\n",
    "# val70_row = val70_row[:-3] + \"\\\\\\\\\"  # Replace last \"& \" with \"\\\\\"\n",
    "# print(val70_row)\n",
    "# print(r\"\\hline\")\n",
    "\n",
    "print(r\"\\end{tabular}\")"
   ]
  }
 ],
 "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": 2
}
