{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "\n",
    "method = 'RHGD'\n",
    "methodopt = '20'\n",
    "ratio = 0.05"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 302 epochs\n",
      "Experiment 2 has 302 epochs\n",
      "Experiment 3 has 302 epochs\n",
      "Experiment 4 has 302 epochs\n",
      "Experiment 5 has 302 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 5\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",
    "# Get the accuracy data from the data dictionary\n",
    "all_gradnorms = data['total_hgradnorm']\n",
    "new_all_gradnorms = []\n",
    "for i in range(len(all_gradnorms)):\n",
    "    new_all_gradnorms.append(all_gradnorms[i].cummin(dim=1)[0])\n",
    "all_gradnorms = new_all_gradnorms\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_gradnorms)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_gradnorms = []\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_gradnorm = all_gradnorms[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_gradnorm)\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_gradnorm = np.pad(train_gradnorm, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_gradnorm[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_gradnorm = train_gradnorm[:max_epochs]\n",
    "        train_gradnorm = train_gradnorm.numpy()\n",
    "    \n",
    "   \n",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms1 = np.array(train_gradnorms)\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 302 epochs\n",
      "Experiment 2 has 302 epochs\n",
      "Experiment 3 has 302 epochs\n",
      "Experiment 4 has 302 epochs\n",
      "Experiment 5 has 302 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 1\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",
    "# Get the accuracy data from the data dictionary\n",
    "all_gradnorms = data['total_hgradnorm']\n",
    "new_all_gradnorms = []\n",
    "for i in range(len(all_gradnorms)):\n",
    "    new_all_gradnorms.append(all_gradnorms[i].cummin(dim=1)[0])\n",
    "all_gradnorms = new_all_gradnorms\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_gradnorms)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_gradnorms = []\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_gradnorm = all_gradnorms[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_gradnorm)\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_gradnorm = np.pad(train_gradnorm, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_gradnorm[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_gradnorm = train_gradnorm[:max_epochs]\n",
    "        train_gradnorm = train_gradnorm.numpy()\n",
    "    \n",
    "   \n",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms2 = np.array(train_gradnorms)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 302 epochs\n",
      "Experiment 2 has 302 epochs\n",
      "Experiment 3 has 302 epochs\n",
      "Experiment 4 has 302 epochs\n",
      "Experiment 5 has 302 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 0.5\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",
    "# Get the accuracy data from the data dictionary\n",
    "all_gradnorms = data['total_hgradnorm']\n",
    "new_all_gradnorms = []\n",
    "for i in range(len(all_gradnorms)):\n",
    "    new_all_gradnorms.append(all_gradnorms[i].cummin(dim=1)[0])\n",
    "all_gradnorms = new_all_gradnorms\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_gradnorms)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_gradnorms = []\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_gradnorm = all_gradnorms[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_gradnorm)\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_gradnorm = np.pad(train_gradnorm, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_gradnorm[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_gradnorm = train_gradnorm[:max_epochs]\n",
    "        train_gradnorm = train_gradnorm.numpy()\n",
    "    \n",
    "   \n",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms3 = np.array(train_gradnorms)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 302 epochs\n",
      "Experiment 2 has 302 epochs\n",
      "Experiment 3 has 302 epochs\n",
      "Experiment 4 has 302 epochs\n",
      "Experiment 5 has 302 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 0.1\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",
    "# Get the accuracy data from the data dictionary\n",
    "all_gradnorms = data['total_hgradnorm']\n",
    "new_all_gradnorms = []\n",
    "for i in range(len(all_gradnorms)):\n",
    "    new_all_gradnorms.append(all_gradnorms[i].cummin(dim=1)[0])\n",
    "all_gradnorms = new_all_gradnorms\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_gradnorms)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_gradnorms = []\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_gradnorm = all_gradnorms[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_gradnorm)\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_gradnorm = np.pad(train_gradnorm, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_gradnorm[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_gradnorm = train_gradnorm[:max_epochs]\n",
    "        train_gradnorm = train_gradnorm.numpy()\n",
    "    \n",
    "   \n",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms4 = np.array(train_gradnorms)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 302 epochs\n",
      "Experiment 2 has 302 epochs\n",
      "Experiment 3 has 302 epochs\n",
      "Experiment 4 has 302 epochs\n",
      "Experiment 5 has 302 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 0.05\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",
    "# Get the accuracy data from the data dictionary\n",
    "all_gradnorms = data['total_hgradnorm']\n",
    "new_all_gradnorms = []\n",
    "for i in range(len(all_gradnorms)):\n",
    "    new_all_gradnorms.append(all_gradnorms[i].cummin(dim=1)[0])\n",
    "all_gradnorms = new_all_gradnorms\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_gradnorms)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_gradnorms = []\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_gradnorm = all_gradnorms[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_gradnorm)\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_gradnorm = np.pad(train_gradnorm, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_gradnorm[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_gradnorm = train_gradnorm[:max_epochs]\n",
    "        train_gradnorm = train_gradnorm.numpy()\n",
    "    \n",
    "   \n",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms5 = np.array(train_gradnorms)"
   ]
  },
  {
   "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_gradnorm1 = np.mean(train_gradnorms1, axis=0)\n",
    "std_train_gradnorm1 = np.std(train_gradnorms1, axis=0)\n",
    "mean_train_gradnorm2 = np.mean(train_gradnorms2, axis=0)\n",
    "std_train_gradnorm2 = np.std(train_gradnorms2, axis=0)\n",
    "mean_train_gradnorm3 = np.mean(train_gradnorms3, axis=0)\n",
    "std_train_gradnorm3 = np.std(train_gradnorms3, axis=0)\n",
    "mean_train_gradnorm4 = np.mean(train_gradnorms4, axis=0)\n",
    "std_train_gradnorm4 = np.std(train_gradnorms4, axis=0)\n",
    "mean_train_gradnorm5 = np.mean(train_gradnorms5, axis=0)\n",
    "std_train_gradnorm5 = np.std(train_gradnorms5, 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_gradnorm1))\n",
    "plt.semilogy(epochs, mean_train_gradnorm1, color='blue', label='5')\n",
    "plt.fill_between(epochs, mean_train_gradnorm1 - 0.5*std_train_gradnorm1, mean_train_gradnorm1 + 0.5*std_train_gradnorm1, \n",
    "                 color='blue', alpha=0.3)\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "epochs = range(len(mean_train_gradnorm2))\n",
    "plt.semilogy(epochs, mean_train_gradnorm2, color='green', label='1')\n",
    "plt.fill_between(epochs, mean_train_gradnorm2 - 0.5*std_train_gradnorm2, mean_train_gradnorm2 + 0.5*std_train_gradnorm2, \n",
    "                 color='green', alpha=0.3)\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "epochs = range(len(mean_train_gradnorm3))\n",
    "plt.semilogy(epochs, mean_train_gradnorm3, color='orange', label='0.5')\n",
    "plt.fill_between(epochs, mean_train_gradnorm3 - 0.5*std_train_gradnorm3, mean_train_gradnorm3 + 0.5*std_train_gradnorm3, \n",
    "                 color='orange', alpha=0.3)\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "epochs = range(len(mean_train_gradnorm4))\n",
    "plt.semilogy(epochs, mean_train_gradnorm4, color='red', label='0.1')\n",
    "plt.fill_between(epochs, mean_train_gradnorm4 - 0.5*std_train_gradnorm4, mean_train_gradnorm4 + 0.5*std_train_gradnorm4, \n",
    "                 color='red', alpha=0.3)\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "epochs = range(len(mean_train_gradnorm5))\n",
    "plt.semilogy(epochs, mean_train_gradnorm5, color='purple', label='0.05')\n",
    "plt.fill_between(epochs, mean_train_gradnorm5 - 0.5*std_train_gradnorm5, mean_train_gradnorm5 + 0.5*std_train_gradnorm5, \n",
    "                 color='purple', alpha=0.3)\n",
    "\n",
    "plt.xlabel('Epochs', fontsize=17)\n",
    "plt.xlim([-1, 301])\n",
    "plt.ylabel('Hypergrad Norm', 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_gradnorm_{method}_{methodopt}_bestiter.png')\n",
    "plt.savefig(f'../fig/robust_dataratio{ratio}_deep_hyrep_spd_gradnorm_{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
}
