{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "ratio = 0.05\n",
    "method = 'AdaRHD'\n",
    "methodopt = 'gd'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 306 epochs\n",
      "Experiment 2 has 306 epochs\n",
      "Experiment 3 has 306 epochs\n",
      "Experiment 4 has 306 epochs\n",
      "Experiment 5 has 306 epochs\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"
     ]
    }
   ],
   "source": [
    "lr = 5.0\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",
    "# Get the accuracy data from the data dictionary\n",
    "all_accuracies = data['accuracy']\n",
    "new_all_accuracies = []\n",
    "for i in range(len(all_accuracies)):\n",
    "    new_all_accuracies.append(all_accuracies[i].cummax(dim=1)[0])\n",
    "all_accuracies = new_all_accuracies\n",
    "\n",
    "all_test_accuracies = data['test_accuracy']\n",
    "new_all_test_accuracies = []\n",
    "for i in range(len(all_test_accuracies)):\n",
    "    new_all_test_accuracies.append(all_test_accuracies[i].cummax(dim=1)[0])\n",
    "all_test_accuracies = new_all_test_accuracies\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_accuracies)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_accuracies = []\n",
    "test_accuracies = []\n",
    "max_epochs = 301  # Target length for all experiments\n",
    "\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    train_acc = all_accuracies[i].reshape(-1)\n",
    "    \n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_acc)\n",
    "    print(f\"Experiment {i+1} has {num_epochs} epochs\")\n",
    "    \n",
    "    # If less than max_epochs, pad with the last value\n",
    "    if num_epochs < max_epochs:\n",
    "        train_acc = np.pad(train_acc, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_acc[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_acc = train_acc[:max_epochs]\n",
    "        train_acc = train_acc.numpy()\n",
    "    \n",
    "    # Add to our list\n",
    "    train_accuracies.append(train_acc)\n",
    "    \n",
    "    # Same for test accuracy if available\n",
    "    if i < len(all_test_accuracies):\n",
    "        test_acc = all_test_accuracies[i].reshape(-1)\n",
    "        if len(test_acc) < max_epochs:\n",
    "            test_acc = np.pad(test_acc, (0, max_epochs - len(test_acc)),\n",
    "                                'constant', constant_values=test_acc[-1])\n",
    "        else:\n",
    "            test_acc = test_acc[:max_epochs]\n",
    "            test_acc = test_acc.numpy()\n",
    "        test_accuracies.append(test_acc)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_accuracies1 = np.array(train_accuracies)\n",
    "test_accuracies1 = np.array(test_accuracies) if test_accuracies else None\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 70% val acc: {val70time_mean1:.2f} ± {val70time_std1:.2f} seconds\")\n",
    "\n",
    "val85times1 = data['val85_time']\n",
    "val85times1 = np.array([t.item() for t in val85times1])\n",
    "val85time_mean1 = np.mean(val85times1)\n",
    "val85time_std1 = np.std(val85times1)\n",
    "\n",
    "print(f\"Mean time for 85% val acc: {val85time_mean1:.2f} ± {val85time_std1:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 306 epochs\n",
      "Experiment 2 has 306 epochs\n",
      "Experiment 3 has 306 epochs\n",
      "Experiment 4 has 306 epochs\n",
      "Experiment 5 has 306 epochs\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"
     ]
    }
   ],
   "source": [
    "lr = 1.0\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",
    "# Get the accuracy data from the data dictionary\n",
    "all_accuracies = data['accuracy']\n",
    "new_all_accuracies = []\n",
    "for i in range(len(all_accuracies)):\n",
    "    new_all_accuracies.append(all_accuracies[i].cummax(dim=1)[0])\n",
    "all_accuracies = new_all_accuracies\n",
    "\n",
    "all_test_accuracies = data['test_accuracy']\n",
    "new_all_test_accuracies = []\n",
    "for i in range(len(all_test_accuracies)):\n",
    "    new_all_test_accuracies.append(all_test_accuracies[i].cummax(dim=1)[0])\n",
    "all_test_accuracies = new_all_test_accuracies\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_accuracies)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_accuracies = []\n",
    "test_accuracies = []\n",
    "max_epochs = 301  # Target length for all experiments\n",
    "\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    train_acc = all_accuracies[i].reshape(-1)\n",
    "    \n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_acc)\n",
    "    print(f\"Experiment {i+1} has {num_epochs} epochs\")\n",
    "    \n",
    "    # If less than max_epochs, pad with the last value\n",
    "    if num_epochs < max_epochs:\n",
    "        train_acc = np.pad(train_acc, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_acc[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_acc = train_acc[:max_epochs]\n",
    "        train_acc = train_acc.numpy()\n",
    "    \n",
    "    # Add to our list\n",
    "    train_accuracies.append(train_acc)\n",
    "    \n",
    "    # Same for test accuracy if available\n",
    "    if i < len(all_test_accuracies):\n",
    "        test_acc = all_test_accuracies[i].reshape(-1)\n",
    "        if len(test_acc) < max_epochs:\n",
    "            test_acc = np.pad(test_acc, (0, max_epochs - len(test_acc)),\n",
    "                                'constant', constant_values=test_acc[-1])\n",
    "        else:\n",
    "            test_acc = test_acc[:max_epochs]\n",
    "            test_acc = test_acc.numpy()\n",
    "        test_accuracies.append(test_acc)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_accuracies2 = np.array(train_accuracies)\n",
    "test_accuracies2 = np.array(test_accuracies) if test_accuracies else None\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\")\n",
    "\n",
    "val85times2 = data['val85_time']\n",
    "val85times2 = np.array([t.item() for t in val85times2])\n",
    "val85time_mean2 = np.mean(val85times2)\n",
    "val85time_std2 = np.std(val85times2)\n",
    "\n",
    "print(f\"Mean time for 85% val acc: {val85time_mean2:.2f} ± {val85time_std2:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 306 epochs\n",
      "Experiment 2 has 306 epochs\n",
      "Experiment 3 has 306 epochs\n",
      "Experiment 4 has 306 epochs\n",
      "Experiment 5 has 306 epochs\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"
     ]
    }
   ],
   "source": [
    "lr = 0.5\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",
    "# Get the accuracy data from the data dictionary\n",
    "all_accuracies = data['accuracy']\n",
    "new_all_accuracies = []\n",
    "for i in range(len(all_accuracies)):\n",
    "    new_all_accuracies.append(all_accuracies[i].cummax(dim=1)[0])\n",
    "all_accuracies = new_all_accuracies\n",
    "\n",
    "all_test_accuracies = data['test_accuracy']\n",
    "new_all_test_accuracies = []\n",
    "for i in range(len(all_test_accuracies)):\n",
    "    new_all_test_accuracies.append(all_test_accuracies[i].cummax(dim=1)[0])\n",
    "all_test_accuracies = new_all_test_accuracies\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_accuracies)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_accuracies = []\n",
    "test_accuracies = []\n",
    "max_epochs = 301  # Target length for all experiments\n",
    "\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    train_acc = all_accuracies[i].reshape(-1)\n",
    "    \n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_acc)\n",
    "    print(f\"Experiment {i+1} has {num_epochs} epochs\")\n",
    "    \n",
    "    # If less than max_epochs, pad with the last value\n",
    "    if num_epochs < max_epochs:\n",
    "        train_acc = np.pad(train_acc, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_acc[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_acc = train_acc[:max_epochs]\n",
    "        train_acc = train_acc.numpy()\n",
    "    \n",
    "    # Add to our list\n",
    "    train_accuracies.append(train_acc)\n",
    "    \n",
    "    # Same for test accuracy if available\n",
    "    if i < len(all_test_accuracies):\n",
    "        test_acc = all_test_accuracies[i].reshape(-1)\n",
    "        if len(test_acc) < max_epochs:\n",
    "            test_acc = np.pad(test_acc, (0, max_epochs - len(test_acc)),\n",
    "                                'constant', constant_values=test_acc[-1])\n",
    "        else:\n",
    "            test_acc = test_acc[:max_epochs]\n",
    "            test_acc = test_acc.numpy()\n",
    "        test_accuracies.append(test_acc)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_accuracies3 = np.array(train_accuracies)\n",
    "test_accuracies3 = np.array(test_accuracies) if test_accuracies else None\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\")\n",
    "\n",
    "val85times3 = data['val85_time']\n",
    "val85times3 = np.array([t.item() for t in val85times3])\n",
    "val85time_mean3 = np.mean(val85times3)\n",
    "val85time_std3 = np.std(val85times3)\n",
    "\n",
    "print(f\"Mean time for 85% val acc: {val85time_mean3:.2f} ± {val85time_std3:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 306 epochs\n",
      "Experiment 2 has 306 epochs\n",
      "Experiment 3 has 306 epochs\n",
      "Experiment 4 has 306 epochs\n",
      "Experiment 5 has 306 epochs\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"
     ]
    }
   ],
   "source": [
    "lr = 0.1\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",
    "# Get the accuracy data from the data dictionary\n",
    "all_accuracies = data['accuracy']\n",
    "new_all_accuracies = []\n",
    "for i in range(len(all_accuracies)):\n",
    "    new_all_accuracies.append(all_accuracies[i].cummax(dim=1)[0])\n",
    "all_accuracies = new_all_accuracies\n",
    "\n",
    "all_test_accuracies = data['test_accuracy']\n",
    "new_all_test_accuracies = []\n",
    "for i in range(len(all_test_accuracies)):\n",
    "    new_all_test_accuracies.append(all_test_accuracies[i].cummax(dim=1)[0])\n",
    "all_test_accuracies = new_all_test_accuracies\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_accuracies)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_accuracies = []\n",
    "test_accuracies = []\n",
    "max_epochs = 301  # Target length for all experiments\n",
    "\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    train_acc = all_accuracies[i].reshape(-1)\n",
    "    \n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_acc)\n",
    "    print(f\"Experiment {i+1} has {num_epochs} epochs\")\n",
    "    \n",
    "    # If less than max_epochs, pad with the last value\n",
    "    if num_epochs < max_epochs:\n",
    "        train_acc = np.pad(train_acc, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_acc[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_acc = train_acc[:max_epochs]\n",
    "        train_acc = train_acc.numpy()\n",
    "    \n",
    "    # Add to our list\n",
    "    train_accuracies.append(train_acc)\n",
    "    \n",
    "    # Same for test accuracy if available\n",
    "    if i < len(all_test_accuracies):\n",
    "        test_acc = all_test_accuracies[i].reshape(-1)\n",
    "        if len(test_acc) < max_epochs:\n",
    "            test_acc = np.pad(test_acc, (0, max_epochs - len(test_acc)),\n",
    "                                'constant', constant_values=test_acc[-1])\n",
    "        else:\n",
    "            test_acc = test_acc[:max_epochs]\n",
    "            test_acc = test_acc.numpy()\n",
    "        test_accuracies.append(test_acc)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_accuracies4 = np.array(train_accuracies)\n",
    "test_accuracies4 = np.array(test_accuracies) if test_accuracies else None\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\")\n",
    "\n",
    "val85times4 = data['val85_time']\n",
    "val85times4 = np.array([t.item() for t in val85times4])\n",
    "val85time_mean4 = np.mean(val85times4)\n",
    "val85time_std4 = np.std(val85times4)\n",
    "\n",
    "print(f\"Mean time for 85% val acc: {val85time_mean4:.2f} ± {val85time_std4:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 306 epochs\n",
      "Experiment 2 has 306 epochs\n",
      "Experiment 3 has 306 epochs\n",
      "Experiment 4 has 306 epochs\n",
      "Experiment 5 has 306 epochs\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": [
    "lr = 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",
    "# Get the accuracy data from the data dictionary\n",
    "all_accuracies = data['accuracy']\n",
    "new_all_accuracies = []\n",
    "for i in range(len(all_accuracies)):\n",
    "    new_all_accuracies.append(all_accuracies[i].cummax(dim=1)[0])\n",
    "all_accuracies = new_all_accuracies\n",
    "\n",
    "all_test_accuracies = data['test_accuracy']\n",
    "new_all_test_accuracies = []\n",
    "for i in range(len(all_test_accuracies)):\n",
    "    new_all_test_accuracies.append(all_test_accuracies[i].cummax(dim=1)[0])\n",
    "all_test_accuracies = new_all_test_accuracies\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_accuracies)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_accuracies = []\n",
    "test_accuracies = []\n",
    "max_epochs = 301  # Target length for all experiments\n",
    "\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    train_acc = all_accuracies[i].reshape(-1)\n",
    "    \n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_acc)\n",
    "    print(f\"Experiment {i+1} has {num_epochs} epochs\")\n",
    "    \n",
    "    # If less than max_epochs, pad with the last value\n",
    "    if num_epochs < max_epochs:\n",
    "        train_acc = np.pad(train_acc, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_acc[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_acc = train_acc[:max_epochs]\n",
    "        train_acc = train_acc.numpy()\n",
    "    \n",
    "    # Add to our list\n",
    "    train_accuracies.append(train_acc)\n",
    "    \n",
    "    # Same for test accuracy if available\n",
    "    if i < len(all_test_accuracies):\n",
    "        test_acc = all_test_accuracies[i].reshape(-1)\n",
    "        if len(test_acc) < max_epochs:\n",
    "            test_acc = np.pad(test_acc, (0, max_epochs - len(test_acc)),\n",
    "                                'constant', constant_values=test_acc[-1])\n",
    "        else:\n",
    "            test_acc = test_acc[:max_epochs]\n",
    "            test_acc = test_acc.numpy()\n",
    "        test_accuracies.append(test_acc)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_accuracies5 = np.array(train_accuracies)\n",
    "test_accuracies5 = np.array(test_accuracies) if test_accuracies else None\n",
    "\n",
    "val50times5 = data['val50_time']\n",
    "val50times5 = np.array([t.item() for t in val50times5])\n",
    "val50time_mean5 = np.mean(val50times5)\n",
    "val50time_std5 = np.std(val50times5)\n",
    "\n",
    "print(f\"Mean time for 50% val acc: {val50time_mean5:.2f} ± {val50time_std5:.2f} seconds\")\n",
    "\n",
    "val70times5 = data['val70_time']\n",
    "val70times5 = np.array([t.item() for t in val70times5])\n",
    "val70time_mean5 = np.mean(val70times5)\n",
    "val70time_std5 = np.std(val70times5)\n",
    "\n",
    "print(f\"Mean time for 70% val acc: {val70time_mean5:.2f} ± {val70time_std5:.2f} seconds\")\n",
    "\n",
    "val85times5 = data['val85_time']\n",
    "val85times5 = np.array([t.item() for t in val85times5])\n",
    "val85time_mean5 = np.mean(val85times5)\n",
    "val85time_std5 = np.std(val85times5)\n",
    "\n",
    "print(f\"Mean time for 85% val acc: {val85time_mean5:.2f} ± {val85time_std5:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "# Calculate means and standard deviations across experiments\n",
    "mean_train_acc1 = np.mean(train_accuracies1, axis=0)\n",
    "std_train_acc1 = np.std(train_accuracies1, axis=0)\n",
    "mean_test_acc1 = np.mean(test_accuracies1, axis=0)\n",
    "std_test_acc1 = np.std(test_accuracies1, axis=0)\n",
    "\n",
    "mean_train_acc2 = np.mean(train_accuracies2, axis=0)\n",
    "std_train_acc2 = np.std(train_accuracies2, axis=0)\n",
    "mean_test_acc2 = np.mean(test_accuracies2, axis=0)\n",
    "std_test_acc2 = np.std(test_accuracies2, axis=0)\n",
    "\n",
    "mean_train_acc3 = np.mean(train_accuracies3, axis=0)\n",
    "std_train_acc3 = np.std(train_accuracies3, axis=0)\n",
    "mean_test_acc3 = np.mean(test_accuracies3, axis=0)\n",
    "std_test_acc3 = np.std(test_accuracies3, axis=0)\n",
    "\n",
    "mean_train_acc4 = np.mean(train_accuracies4, axis=0)\n",
    "std_train_acc4 = np.std(train_accuracies4, axis=0)\n",
    "mean_test_acc4 = np.mean(test_accuracies4, axis=0)\n",
    "std_test_acc4 = np.std(test_accuracies4, axis=0)\n",
    "\n",
    "mean_train_acc5 = np.mean(train_accuracies5, axis=0)\n",
    "std_train_acc5 = np.std(train_accuracies5, axis=0)\n",
    "mean_test_acc5 = np.mean(test_accuracies5, axis=0)\n",
    "std_test_acc5 = np.std(test_accuracies5, axis=0)\n",
    "\n",
    "# Create a figure\n",
    "plt.figure(figsize=(5, 4))\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "epochs = range(len(mean_train_acc1))\n",
    "plt.plot(epochs, mean_train_acc1, color='blue', label='5')\n",
    "plt.fill_between(epochs, mean_train_acc1 - 0.5*std_train_acc1, mean_train_acc1 + 0.5*std_train_acc1, \n",
    "                 color='blue', alpha=0.3)\n",
    "\n",
    "epochs = range(len(mean_train_acc2))\n",
    "plt.plot(epochs, mean_train_acc2, color='green', label='1')\n",
    "plt.fill_between(epochs, mean_train_acc2 - 0.5*std_train_acc2, mean_train_acc2 + 0.5*std_train_acc2, \n",
    "                 color='green', alpha=0.3)\n",
    "\n",
    "epochs = range(len(mean_train_acc3))\n",
    "plt.plot(epochs, mean_train_acc3, color='orange', label='0.5')\n",
    "plt.fill_between(epochs, mean_train_acc3 - 0.5*std_train_acc3, mean_train_acc3 + 0.5*std_train_acc3, \n",
    "                 color='orange', alpha=0.3)\n",
    "epochs = range(len(mean_train_acc4))\n",
    "\n",
    "plt.plot(epochs, mean_train_acc4, color='red', label='0.1')\n",
    "plt.fill_between(epochs, mean_train_acc4 - 0.5*std_train_acc4, mean_train_acc4 + 0.5*std_train_acc4, \n",
    "                 color='red', alpha=0.3)\n",
    "\n",
    "epochs = range(len(mean_train_acc5))\n",
    "plt.plot(epochs, mean_train_acc5, color='purple', label='0.05')\n",
    "plt.fill_between(epochs, mean_train_acc5 - 0.5*std_train_acc5, mean_train_acc5 + 0.5*std_train_acc5, \n",
    "                 color='purple', alpha=0.3)\n",
    "\n",
    "plt.xlabel('Epochs', fontsize=17)\n",
    "plt.xlim([-1, 301])\n",
    "plt.ylabel('Validation Accuracy', fontsize=17)\n",
    "# plt.title('Validation Accuracy vs Epochs')\n",
    "plt.legend()\n",
    "# plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f'../fig/robust_dataratio{ratio}_deep_hyrep_spd_acc_{method}_{methodopt}_bestiter.png', bbox_inches='tight')\n",
    "plt.savefig(f'../fig/robust_dataratio{ratio}_deep_hyrep_spd_acc_{method}_{methodopt}_bestiter.pdf', format='pdf', bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "  \n"
   ]
  }
 ],
 "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
}
