{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 165,
   "id": "36fb808e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "\n",
    "model = 'mle'\n",
    "d = 50\n",
    "n = 1000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "id": "0f2751be",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 307 epochs\n",
      "Experiment 2 has 307 epochs\n",
      "Experiment 3 has 307 epochs\n",
      "Experiment 4 has 307 epochs\n",
      "Experiment 5 has 307 epochs\n",
      "Experiment 1 has 307 epochs\n",
      "Experiment 2 has 307 epochs\n",
      "Experiment 3 has 307 epochs\n",
      "Experiment 4 has 307 epochs\n",
      "Experiment 5 has 307 epochs\n"
     ]
    }
   ],
   "source": [
    "method = 'AdaRHD'\n",
    "methodopt = 'gd'\n",
    "with open(f'../results/robust_{model}_n{n}d{d}_{method}_{methodopt}_lr0.1.pickle', '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",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms_AdaRHD_gd = np.array(train_gradnorms)\n",
    "\n",
    "all_times = data['runtime']\n",
    "new_all_times = []\n",
    "for i in range(len(all_times)):\n",
    "    new_all_times.append(all_times[i].cumsum(dim=1)[0])\n",
    "all_times = new_all_times\n",
    "\n",
    "times = []\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    time = all_times[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(time)\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",
    "        time = np.pad(time, (0, max_epochs - num_epochs),\n",
    "                      'constant', constant_values=time[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        time = time[:max_epochs]\n",
    "        time = time.numpy()\n",
    "\n",
    "    # Add to our list\n",
    "    times.append(time)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "AdaRHD_gd_times = np.array(times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "id": "be921773",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 301 epochs\n",
      "Experiment 2 has 301 epochs\n",
      "Experiment 3 has 301 epochs\n",
      "Experiment 4 has 301 epochs\n",
      "Experiment 5 has 301 epochs\n",
      "Experiment 1 has 301 epochs\n",
      "Experiment 2 has 301 epochs\n",
      "Experiment 3 has 301 epochs\n",
      "Experiment 4 has 301 epochs\n",
      "Experiment 5 has 301 epochs\n"
     ]
    }
   ],
   "source": [
    "method = 'AdaRHD'\n",
    "methodopt = 'cg'\n",
    "with open(f'../results/robust_{model}_n{n}d{d}_{method}_{methodopt}_lr0.1.pickle', '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",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms_AdaRHD_cg = np.array(train_gradnorms)\n",
    "\n",
    "all_times = data['runtime']\n",
    "new_all_times = []\n",
    "for i in range(len(all_times)):\n",
    "    new_all_times.append(all_times[i].cumsum(dim=1)[0])\n",
    "all_times = new_all_times\n",
    "\n",
    "times = []\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    time = all_times[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(time)\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",
    "        time = np.pad(time, (0, max_epochs - num_epochs),\n",
    "                      'constant', constant_values=time[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        time = time[:max_epochs]\n",
    "        time = time.numpy()\n",
    "\n",
    "    # Add to our list\n",
    "    times.append(time)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "AdaRHD_cg_times = np.array(times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "id": "31f412df",
   "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",
      "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"
     ]
    }
   ],
   "source": [
    "method = 'RHGD'\n",
    "methodopt = '20'\n",
    "with open(f'../results/robust_{model}_n{n}d{d}_{method}_{methodopt}_lr0.1.pickle', '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_gradnorms_RHGD_20 = np.array(train_gradnorms)\n",
    "\n",
    "all_times = data['runtime']\n",
    "new_all_times = []\n",
    "for i in range(len(all_times)):\n",
    "    new_all_times.append(all_times[i].cumsum(dim=1)[0])\n",
    "all_times = new_all_times\n",
    "\n",
    "times = []\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    time = all_times[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(time)\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",
    "        time = np.pad(time, (0, max_epochs - num_epochs),\n",
    "                      'constant', constant_values=time[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        time = time[:max_epochs]\n",
    "        time = time.numpy()\n",
    "\n",
    "    # Add to our list\n",
    "    times.append(time)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "RHGD_20_times = np.array(times)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "id": "bc1d8861",
   "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",
      "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"
     ]
    }
   ],
   "source": [
    "method = 'RHGD'\n",
    "methodopt = '50'\n",
    "with open(f'../results/robust_{model}_n{n}d{d}_{method}_{methodopt}_lr0.1.pickle', '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_gradnorms_RHGD_50 = np.array(train_gradnorms)\n",
    "\n",
    "all_times = data['runtime']\n",
    "new_all_times = []\n",
    "for i in range(len(all_times)):\n",
    "    new_all_times.append(all_times[i].cumsum(dim=1)[0])\n",
    "all_times = new_all_times\n",
    "\n",
    "times = []\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    time = all_times[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(time)\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",
    "        time = np.pad(time, (0, max_epochs - num_epochs),\n",
    "                      'constant', constant_values=time[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        time = time[:max_epochs]\n",
    "        time = time.numpy()\n",
    "\n",
    "    # Add to our list\n",
    "    times.append(time)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "RHGD_50_times = np.array(times)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "id": "28ea7d23",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_train_gradnorm1_AdaRHD_gd = np.mean(train_gradnorms_AdaRHD_gd, axis=0)\n",
    "mean_train_gradnorm1_AdaRHD_cg = np.mean(train_gradnorms_AdaRHD_cg, axis=0)\n",
    "mean_train_gradnorm1_RHGD_20 = np.mean(train_gradnorms_RHGD_20, axis=0)\n",
    "mean_train_gradnorm1_RHGD_50 = np.mean(train_gradnorms_RHGD_50, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "id": "5001127e",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_time_AdaRHD_gd = np.mean(AdaRHD_gd_times, axis=0)\n",
    "mean_time_AdaRHD_cg = np.mean(AdaRHD_cg_times, axis=0)\n",
    "mean_time_RHGD_20 = np.mean(RHGD_20_times, axis=0)\n",
    "mean_time_RHGD_50 = np.mean(RHGD_50_times, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "id": "e5b65532",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeoAAAGGCAYAAAC0W8IbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAACMr0lEQVR4nOzdd3gUVRfA4d9uekhPSINAgNBL6AGRHkWqIAqfAtLEBoiiiFgAsWClCLFTFKTYAAsqSJcqTXoPPYUA6aTu/f4YsiSkkGw22SSc93nm2d2ZuzNnCHBy79yiU0ophBBCCFEm6S0dgBBCCCHyJ4laCCGEKMMkUQshhBBlmCRqIYQQogyTRC2EEEKUYZKohRBCiDJMErUQQghRhkmiFkIIIcowa0sHUFEYDAYuX76Ms7MzOp3O0uEIIYQow5RSJCQk4O/vj15fcJ1ZErWZXL58mYCAAEuHIYQQohy5cOECVatWLbCMJOpiCgsLIywsjIyMDED7Q3dxcbFwVEIIIcqy+Ph4AgICcHZ2vmNZncz1bR7x8fG4uroSFxcniVoIIUSBipIzpDOZEEIIUYZJohZCCCHKMEnUxRQWFkaDBg1o1aqVpUMRQghRAckzajORZ9RCCIPBQFpamqXDEGWAjY0NVlZW+R4vSs6QXt9CCGEGaWlphIeHYzAYLB2KKCPc3Nzw9fUt9twakqiFEKKYlFJERERgZWVFQEDAHSewEBWbUork5GSio6MB8PPzK9b5JFELIUQxZWRkkJycjL+/P46OjpYOR5QBDg4OAERHR+Pt7V1gM/idyK99QghRTJmZmQDY2tpaOBJRlmT90paenl6s80iiLibp9S2EyCLz/IvszPX3QRJ1MY0ePZojR47w77//WjoUIYQQFZAkajP7a+taIiLItd1sGRNCiHJt6tSpNG3a1NJh3FUkUZtZuz4P081/H/7+5NjatgUZtSGEKIu2b9+OlZUVPXv2LJHzBwYGotPp0Ol0ODo60rhxY77++uscZTZu3IhOpyM2NjbP78+aNSvP8zk4OBAYGMiAAQNYv359oWM6deoUI0aMoFq1atjZ2VGlShW6du3Kd999Z1xkCTBeR6fTUalSJWrXrs2wYcPYs2dPkf8cTCWJ2sycMuBb+37Y69OwsoKsjn7//gubN1s2NiGEyMu8efMYO3Ysmzdv5vLlyyVyjWnTphEREcGhQ4cYPHgwo0aN4o8//ij2+Y4fP863336Lm5sboaGhvPPOO3f87q5du2jevDlHjx4lLCyMQ4cOsXHjRp544gk+++wzDh8+nKP8ggULiIiI4PDhw4SFhZGYmEhISAjffvutyfEXhSRqM7tqD01TznHjvdlkZEBGBjz5pHbstl8ghRDC4hITE1m+fDnPPPMMPXv2ZOHChTmOv/fee/j4+ODs7MzIkSNJSUnJcfzff//lvvvuw8vLC1dXVzp27MjevXtzXcfZ2RlfX19q1qzJxIkT8fDwYO3atSbHnXW+atWq0aFDB7788kveeOMNJk+ezPHjx/P9nlKKYcOGUadOHbZu3Urv3r2pXbs2tWvX5tFHH+Wff/6hSZMmOb6TNXFJYGAg999/Pz/++CODBg1izJgxXL9+3eR7KCxJ1Gb2Ybubb7ZsMe574gnt9ccfoRR+pkIIC1MKkpIssxV1Uujvv/+eevXqUbduXQYPHsz8+fPJmln6+++/Z+rUqbz77rvs3r0bPz8/Pv300xzfT0hIYOjQofzzzz/s2LGD2rVr06NHDxISEvK8nsFg4KeffuL69etmH842btw4lFKsWrUq3zL79+/n6NGjvPTSS/lOTFOY3tovvPACCQkJxfplo7BkwpNiCgsLIywszDiO8qjXzQOnTxvLtGwJ9erBsWNa/u7TxwKBCiFKTXIyODlZ5tqJiVCpUuHLz5s3j8GDBwPwwAMPEBcXx6ZNm+jUqROzZs1i5MiRjBw5EoC3336bv//+O0etukuXLjnO9+WXX+Lm5samTZvo1auXcf/EiRN5/fXXSU1NJSMjAw8PD57IqsVkU7Vq1Vz7kpOTC3UvHh4eeHt7c/bs2XzLnDhxAoC6desa90VHR1OzZk3j5w8++IBnn322wGvVq1cPoMBrmYvUqIvp9uFZZ91uHjhzxvirrU4HWX8nLl4s/RiFECIvx48fZ9euXTz66KMAWFtbM3DgQObNmwfA0aNHCQkJyfGdtm3b5vgcFRXFqFGjqF27Nq6urri4uJCYmMj58+dzlJswYQL79+9n/fr1hISEMHPmTIKCgnLFtGXLFvbv359j8/f3L/Q9KaWMNeKGDRvi5OSEk5MT3bt3z/c7np6exmu5ubkVamEVZfz/veTHzkuN2swuuEKmDqxSUiAyEm7O8Zr1S+KlSxYMTghRKhwdtZqtpa5dWPPmzSMjIyNHIlRKYWdnx9y5cwt1jqFDh3L16lVmz55N9erVsbOzo23btrmSnZeXF0FBQQQFBfHDDz/QuHFjWrZsSYMGDXKUq1GjBm5ubjn2WVsXLlVdvXqVK1euUKNGDQBWr15tnBUsa0rP2rVrA9ovKc2aNQPAysrK+EtDYa919OhRY7wlTRK1mWXq4bwr1IhFa/6+mairVNGOS6IWouLT6YrW/GwJGRkZfPvtt3z88cfcf//9OY717duXpUuXUr9+fXbu3Mnjjz9uPLZjx44cZbdu3cqnn35Kjx49ALhw4QIxMTEFXjsgIICBAwcyadKkAp8nF9Xs2bPR6/X07dsXgOrVq+cq06xZM+rVq8dHH33EgAEDTF5AZdasWbi4uBAaGlqckAtFErWZeVjBafebifrMGbj3XkAStRCibPntt9+4fv06I0eOxNXVNcex/v37M2/ePF566SWGDRtGy5YtadeuHd999x2HDx/O8Ty3du3aLFq0iJYtWxIfH8+ECROMtdeCjBs3jkaNGrF7925atmxZ5PgTEhKIjIwkPT2d8PBwFi9ezNdff8306dPzbFLPotPpWLBgAffddx/t2rVj0qRJ1K9fn/T0dDZv3syVK1dyLaARGxtLZGQkqampnDhxgi+++IKVK1cah4WVNHlGbWZeVnDG/eaHM2eM+yVRCyHKknnz5hEaGporSYOWqHfv3k39+vV54403ePnll2nRogXnzp3jmWeeyXWe69ev07x5c4YMGcJzzz2Ht7f3Ha/foEED7r//fiZPnmxS/JMnT8bPz4+goCCGDBlCXFwc69atY+LEiXf8bps2bdizZw9169Zl9OjRNGjQgHvuuYelS5cyc+bMXPc4fPhw/Pz8qFevHs888wxOTk7s2rWLxx57zKTYi0qnVFE781dc/fr1Y+PGjXTt2pUff/yxSN+Nj4/H1dWVe96E9pvhvXXAkCFwc0D8sWNQvz64uEBcXAkEL4SwmJSUFMLDw6lRowb29vaWDkeUEQX9vcjKGXFxcbi4uBR4HqlRZzNu3LhizzTjZQWnPW5+yDZEK6tGHR8P+QwvFEIIIXKRRJ1Np06dcHZ2LtY58mv6dnbWNpDmbyGEEIVXYRL15s2b6d27N/7+/uh0OlauXJmrTFhYGIGBgdjb2xMSEsKuXbvMHoeXPluijozUZj64SZ5TCyGEKKoKk6iTkpIIDg4mLCwsz+PLly9n/PjxTJkyhb179xIcHEy3bt2Ijo42axyedg7EOkCi480O9dlq1VlDFSMjzXpJIYQQFViFSdTdu3fn7bffpl+/fnkenzFjBqNGjWL48OE0aNCAzz//HEdHR+bPn2/S9VJTU4mPj8+xAXjZaz0oL3nZaAWzJeqsjpBRUSZdUgghxF2owiTqgqSlpbFnz54cA9P1ej2hoaFs377dpHNOnz4dV1dX4xYQEACAl4PWkyw8q0NZtkTt46O9mrkSL4QQogK7KxJ1TEwMmZmZ+GRlypt8fHyIzNYOHRoayiOPPMLq1aupWrVqgUl80qRJxMXFGbcLFy4A4FVJqzafcL258HgeiVpq1EIIIQpLZibL5u+//y50WTs7O+zs7HKtnuVVyReAI87a/LLZh2hJ07cQQoiiuitq1F5eXlhZWRF1W4aMiorC19e3WOe+ffUsTydt9Y2T0vQthKiApk6dStOmTS0dxl3lrkjUtra2tGjRgnXr1hn3GQwG1q1bl2vJtuKycfTBPfsQrfBwMBgAafoWQpRN27dvx8rKip49e5bI+QMDA9HpdOh0OhwdHWncuDFff/11jjIbN25Ep9MRGxub5/dnzZqV5/kcHBwIDAxkwIABrF+/vlDxKKX48ssvCQkJwcnJCTc3N1q2bMmsWbNyrH0dHx/PG2+8QcOGDXFwcMDT05NWrVrxwQcfcP36dZP+LExRYRJ1YmKicT1RgPDwcPbv329cE3X8+PF89dVXfPPNNxw9epRnnnmGpKQkhg8fXqzrhoWF0aBBA1q1aqXtsPWishVccAGDtRWkpsLly0DOGrVM3CqEKCvmzZvH2LFj2bx5M5dv/n9lbtOmTSMiIoJDhw4xePBgRo0axR9//FHs8x0/fty4OEZoaCjvvPPOHb87ZMgQnn/+eR588EE2bNjA/v37eeONN1i1ahVr1qwB4Nq1a7Rp04YFCxbw0ksvsXPnTvbu3cs777zDvn37WLJkicmxF5mqIDZs2KCAXNvQoUONZebMmaOqVaumbG1tVevWrdWOHTvMdv24uDgFqLiTv6l276GYikoI8FUKlNq0SSml1I0b2kdQ6to1s11aCGFhN27cUEeOHFE3btywdChFlpCQoJycnNSxY8fUwIED1TvvvJPj+PTp05W3t7dycnJSI0aMUBMnTlTBwcHG47t27VKhoaHK09NTubi4qA4dOqg9e/bkOEf16tXVzJkzc+zz8PBQL7zwgvFz1v/h169fzxXj7d/P63xKKTV58mSl1+vVsWPH8r3f5cuXK0CtXLky1zGDwaBiY2OVUko99dRTqlKlSurSpUt5nsdgMOR7jSwF/b0w5oy4uDuep8LUqDt16oRSKte2cOFCY5kxY8Zw7tw5UlNT2blzJyEhIcW+bn41aoDr/jfbv28+p7a31xblAHlOLYQoG77//nvq1atH3bp1GTx4MPPnz0fdbPL7/vvvmTp1Ku+++y67d+/Gz8+PTz/9NMf3ExISGDp0KP/88w87duygdu3a9OjRg4R8FjUwGAz89NNPXL9+HVtbW7Pey7hx41BKFbjG9XfffUfdunV58MEHcx3T6XS4urpiMBhYvnw5gwcPxj9rpqo8ypYW6fVdTKNHj2b06NHGlVCwv5Woo7wdCYBcHcri47Xn1HXrWiRkIURJUwoyk+9criRYOUIRksi8efMYPHgwAA888ABxcXFs2rSJTp06MWvWLEaOHMnIkSMBePvtt/n7779JSUkxfr9Lly45zvfll1/i5ubGpk2b6NWrl3H/xIkTef3110lNTSUjIwMPDw+eeOKJXPFUrVo1177sz40L4uHhgbe3N2fPns23zMmTJ6l7h/98r1y5QmxsbK5yLVq04Pjx4wD07t2bpUuXFiqu4jJbor5x4waxsbGkp6cXWK5atWrmumTZZOuB981EfdFDR0vINUTr5EnpUCZEhZaZDN87WebaAxLBulKhih4/fpxdu3axYsUKAKytrRk4cCDz5s2jU6dOHD16lKeffjrHd9q2bcuGDRuMn6Oionj99dfZuHEj0dHRZGZmkpycbOwflGXChAkMGzaMiIgIJkyYwLPPPktQUFCumLZs2ZJrcaROnToV6n5A6yiWVdtt2LAh586dA6B9+/b88ccfxtYCU6xYsYK0tDQmTpzIjRs3TD5PURUrUcfExPDee+/x888/G/8wCqLT6cjIyCjOJcuc28dRo7fC274SkMRpt5u/tMgQLSFEGTRv3jwyMjJyNO8qpbCzs2Pu3LmFOsfQoUO5evUqs2fPpnr16tjZ2dG2bVvS0tJylPPy8iIoKIigoCB++OEHGjduTMuWLWnQoEGOcjVq1MDNzS3HPmvrwqWqq1evcuXKFWrUqAHA6tWrjZVHBwcHAOrUqcOxY8cKPE/lypVxc3Mz1p6zZFU0nZ2d8+ydXlJMTtTh4eF06NCBy5cvF/o3lOL8JlNW5Wr6Bnwc3IAkjjrdbK6R2cmEuLtYOWo1W0tduxAyMjL49ttv+fjjj7n//vtzHOvbty9Lly6lfv367Ny5k8cff9x4bMeOHTnKbt26lU8//ZQePXoAcOHCBWJiYgq8dkBAAAMHDmTSpEkFPk8uqtmzZ6PX6+nbty8A1atXz1Xmscce43//+x+rVq3K9ZxaKWX8v3zAgAEsXryYyZMn5/ucurSYnKgnTJjApUuX8Pf35/3336dr1654e3uj11eY/mkm83bwBC7xX6WbnSmioyEhAZydZXYyIe4GOl2hm58t5bfffuP69euMHDnSWMnI0r9/f+bNm8dLL73EsGHDaNmyJe3ateO7777j8OHD1KxZ01i2du3aLFq0iJYtWxIfH8+ECROMtdeCjBs3jkaNGrF7925atmxZ5PgTEhKIjIwkPT2d8PBwFi9ezNdff8306dPzbFLPMmDAAFasWMGjjz7K66+/zv3330/lypU5ePAgM2fOZOzYsfTt25d3332XjRs30rp1a6ZNm0bLli2pVKkSBw4cYPv27TRq1KjIMZvK5Ky6bt06dDodP//8M4MGDcLX1/euTNK5en0DPk7abGdniAdPT21neLh2TJq+hRBlwLx58wgNDc2VpEFL1Lt376Z+/fq88cYbvPzyy7Ro0YJz587xzDPP5DrP9evXad68OUOGDOG5557DO6tGUoAGDRpw//33M3nyZJPinzx5Mn5+fgQFBTFkyBDi4uJYt24dEydOLPB7Op2OJUuWMGPGDFauXEnHjh1p0qQJU6dO5cEHH6Rbt24AeHp6smvXLh5//HE+/PBDWrduTePGjZk6dSoDBw7kq6++MiluU+iUie3RWT/cuLg4swZUXmU1l8TFxZF28Hkq/70AgMzfWqLfvRtWrIC+ffn5Z+jfH9q2hW3bLBy0EMIsUlJSCA8Pp0aNGtjb21s6HFFGFPT3InvOcMkat5sPk6vADRo0ICUlhdTUVFNPUWF5OAVws+M3qdVuPtu4+Zy6cmXt45UrpR+XEEKI8sfkRD127FjS09NZsGCBOeOpEPT2nsax1HFVbjZ93xyildUSfvWqBQITQghR7pjcmeyxxx5jz549PP/888TGxjJu3LhCdSCoaHINzwKw9cDHCiIzIcbPFV8w1qizEnVsLGRmgpXV7WcUQgghbinWOOqPP/4YDw8PXnvtNd58801q1KhR4LKROp0uxwpWFUFew7Ow9cDbGkiDS5XtaQRw6hQAHjeXv1QKrl8HLy9LRC2EEKK8MDlRK6UYO3Ysn3/+OUopUlNTOXbsWIEDyUtzblSLsrs1O1m4V9abcEhPx8bGBhcXbRrRq1clUQshhCiYyYl6xowZxsnZQ0ND6dKlC97e3lhJW66x6RvgtEMKVKoESUla83fdunh63krUQgghREFMTtRfffUVOp2O9957jwkTJpgzpvIv23zf0clRUKcO7NsHx48bE3V4uCRqIYQQd2Zyr+/z589jZWXFc889Z854yp28JjzB1g2fm78CRSdcvrVM1s15Y6XntxBCiMIyOVH7+vri6OiInZ2dOeMpd0aPHs2RI0f4999/b+3UW+Ntq823G5UUqdWoAU6cACRRCyGEKDyTE3W/fv1ISEjImaCEkbYwB0QnXZEatRBCCJOZnKinTJlC7dq1GTFiRK51RwV4O2rZOPrGdVRWjfq2RH3tmiUiE0IIzbBhw9DpdOh0OmxsbKhRowYvv/wyKSkpxjI6nY6VK1fm+d2sVaqyREZGMm7cOIKCgrC3t8fHx4d27drx2WefkZycbCwXGBhovK6DgwOBgYEMGDCA9evX3zHmjRs38uCDD+Ln50elSpVo2rQp3333Xa5yP/zwA/Xq1cPe3p7GjRuzevXqwv/BlDEmdyZbuXIlTz/9NG+++SZ16tThkUceoVGjRvj5+RX4vezLpVVk3pW0SenTDRnEBlTGHbSVOGJj8fR0A6RGLYSwvAceeIAFCxaQnp7Onj17GDp0KDqdjvfff79I5zlz5gzt2rXDzc2Nd999l8aNG2NnZ8fBgwf58ssvqVKlCn369DGWnzZtGqNGjSItLY2zZ8+yePFiQkNDeeutt3jttdfyvc62bdto0qQJEydOxMfHh99++43HH38cV1dXevXqZSzz6KOPMn36dHr16sWSJUvo27cve/fuLdVVr8zF5ESd9ZtY1poeS5YsKdT37pZEbWfvhase4gwQZXUDdz8/iIiAEyfw8GgNSKIWQlienZ2dcaKqgIAAQkNDWbt2bZET9bPPPou1tTW7d++mUqVbS3zWrFmTBx98kNvXf3J2djZet1q1anTo0AE/Pz8mT57Mww8/TN2sR4a3efXVV3N8HjduHGvWrOHnn382JurZs2fzwAMPGEckvfXWW6xdu5a5c+fy+eefF+m+ygKTE3WHDh3unglMTHFz0pM4A0QnRVOvbl0tUR8/jqe3JGohRNlz6NAhtm3bRvXq1Yv0vatXr7JmzRrefffdHEk6u8Lki3HjxvHWW2+xatUqXn755UJfPy4ujvr16xs/b9++nfHjx+co061btzyb8MsDkxP1xo0bzRhGBXRz0pOT6RCVGKV1KNu4UUvUN/8+SaIWomJSSpGcnnzngiXA0caxSJWo3377DScnJzIyMkhNTUWv1zN37twcZR599NFck1mlpqbSs2dPAE6dOoVSKlct2MvLy/i8e/To0XespXt4eODt7c3Zs2cLHf/333/Pv//+yxdffGHcFxkZiY+PT45yPj4+REZGFvq8ZYnJifqTTz4B4OGHH8bf399sAZU3eS7KATknPUmKvjVE6/hx6fUtRAWXnJ6M03Qni1w7cVIilWzzrtXmpXPnznz22WckJSUxc+ZMrK2t6d+/f44yM2fOJDQ0NMe+iRMn5v5/7za7du3CYDAwaNCgQi+JrJQy/qLRsGFDzp07B0D79u35448/cpTdsGEDw4cP56uvvqJhw4aFOn95ZHKifuGFF7CysuLpp582ZzzlTp6LcgDYeRgnPYlKioK6IdqHEyeMiTolBZKTwdGxdGMWQogslSpVIigoCID58+cTHBzMvHnzGDlypLGMr6+vsUwWZ2dnYmNjAQgKCkKn03H85siWLDVr1gQo9MqKV69e5cqVK9SoUQOA1atXk56enuc5Nm3aRO/evZk5c2auvk++vr5ERUXl2BcVFVXgolFlmcmJunLlyqSnp2Nra2vOeCqO22vU9W42CZ08iXMlA9bWejIytFq1JGohKhZHG0cSJyVa7Nqm0uv1vPrqq4wfP57HHnus0AnW09OT++67j7lz5zJ27Nh8n1PfyezZs9Hr9cZhX/k9K9+4cSO9evXi/fff58knn8x1vG3btqxbt47nn3/euG/t2rW0bdvWpLgszeRx1CEhIcTGxnL58mVzxlNxZFuYIzopGgIDwcYGbtxAd/GCNH8LUYHpdDoq2VayyFbcTr6PPPIIVlZWhIWFFel7n376KRkZGbRs2ZLly5dz9OhRjh8/zuLFizl27FiuZ9wJCQlERkZy4cIFNm/ezJNPPsnbb7/NO++8k6v2nt2GDRvo2bMnzz33HP379ycyMpLIyEiuZZuYYty4cfz55598/PHHHDt2jKlTp7J7927GjBlTtD+MMsLkRD1hwgT0er0syJGfbEtdRiVFgbU11Kql7cjW/C2JWghRllhbWzNmzBg++OADkpKSCv29WrVqsW/fPkJDQ5k0aRLBwcG0bNmSOXPm8NJLL/HWW2/lKD958mT8/PwICgpiyJAhxMXFsW7dOiZOnFjgdb755huSk5OZPn06fn5+xu2hhx4ylrnnnntYsmQJX375JcHBwfz444+sXLmyXI6hBtCp2we3FcGyZct48sknadGiBS+88AJt2rShcuXKd+Wwraxn1HFxcbi4uMCNSP5Z4kf7ixDkEcTJsSehb19YtQrmzKHD92PYsgWWL4cBAywdvRCiOFJSUggPD6dGjRrY29tbOhxRRhT09yJXziiAyc+oszdjbN68mc2bN9/xOzqdjoyMDFMvWeJ+++03XnzxRQwGAxMnTuSJJ54w/WS27rdq1Ik3hwRkDV04dgwPD+3tzb4YQgghRJ5MTtSmVMSLUXkvcRkZGYwfP54NGzbg6upKixYt6NevH55ZbdRFZWWHr609kEJCWiJJaUlUyhqQf+QIrgHaW0nUQgghCmJyog4PDzdnHBa3a9cuGjZsSJUqVQDo3r07a9as4dFHHzX5nM727lTSRZCkICIxgqCscX5HjuDWWHsriVoIIURBTO5MVr16dZO2krJ582Z69+6Nv79/vqu9hIWFERgYiL29PSEhIezatct47PLly8YkDVClShUuXbpUrJh0dh743/xV6HLCZciqUUdF4Wer9SKTRC2EEKIgJifqsiYpKYng4OB8hxQsX76c8ePHM2XKFPbu3UtwcDDdunUjOjq65IKydccve6J2coKbv6zUvHEYkEQthBCiYCY3fd/u8OHD7Nu3jytXrgDahCjNmjUrtWndunfvTvfu3fM9PmPGDEaNGsXw4cMB+Pzzz/n999+ZP38+r7zyCv7+/jlq0JcuXaJ169b5ni81NTXHlHjx8fG5C9m643+zQ9nlhJvjzRs2hHPnqBp/BOggiVoIIUSBip2of/rpJ954441cU8dlqVevHm+99VaOMW6lLS0tjT179jBp0iTjPr1eT2hoKNu3bwegdevWHDp0iEuXLuHq6soff/zBG2+8ke85p0+fzptvvlnwhW3djU3fEQkR2puGDWH1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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Create a figure\n",
    "plt.figure(figsize=(5, 4))\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "plt.semilogy(mean_time_AdaRHD_gd, mean_train_gradnorm1_AdaRHD_gd, color='blue', label='AdaRHD-GD')\n",
    "plt.semilogy(mean_time_AdaRHD_cg, mean_train_gradnorm1_AdaRHD_cg, color='orange', label='AdaRHD-CG')\n",
    "plt.semilogy(mean_time_RHGD_20, mean_train_gradnorm1_RHGD_20, color='green', label='RHGD-20')\n",
    "plt.semilogy(mean_time_RHGD_50, mean_train_gradnorm1_RHGD_50, color='red', label='RHGD-50')\n",
    "\n",
    "max_time = np.max([mean_time_AdaRHD_gd, mean_time_AdaRHD_cg, mean_time_RHGD_20, mean_time_RHGD_50])\n",
    "plt.xlabel('Time(s)', fontsize=17)\n",
    "plt.xlim([-1, max_time])\n",
    "plt.ylabel('Hypergradient 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_{model}_n{n}d{d}_timeVSgradnorms.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": 5
}
