{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import hypergrad as hg\n",
    "import numpy as np\n",
    "import torch.nn.functional as F\n",
    "#from sklearn.datasets import make_spd_matrix as spd\n",
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.random.manual_seed(0)\n",
    "np.random.seed(0)\n",
    "torch.backends.cudnn.deterministic = True\n",
    "torch.backends.cudnn.benchmark = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "p, d, n = 64, 128, 500\n",
    "m = 0.1 \n",
    "\n",
    "H_true = torch.randn((p, d))\n",
    "w_true = torch.randn(d)\n",
    "Xg = torch.randn((n, p))\n",
    "yg = Xg @ H_true @ w_true + m * torch.randn(n)\n",
    "Xf = torch.randn((n, p))\n",
    "yf = Xf @ H_true @ w_true + m * torch.randn(n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "b = 0.1\n",
    "\n",
    "def inner_func(params, hparams):\n",
    "    H = hparams[0]\n",
    "    w = params[0]\n",
    "    \n",
    "    g =  (0.5 * (torch.norm(Xg @ H @ w - yg))**2) / n + 0.5 * b * (torch.norm(w))**2 \n",
    "    return g #.squeeze()\n",
    "\n",
    "def outer_func(params, hparams):\n",
    "    \n",
    "    H = hparams[0]\n",
    "    w = params[0]\n",
    "    \n",
    "    f = (0.5 * (torch.norm(Xf @ H @ w - yf))**2) / n \n",
    "    \n",
    "    return f #.squeeze()\n",
    "\n",
    "alpha = .001\n",
    "p0 = [torch.randn(d)]\n",
    "hp0 = [torch.randn((p, d))]\n",
    "\n",
    "def map_func(params, hparams):\n",
    "    \n",
    "    g = inner_func(params, hparams)\n",
    "    #inner_losses.append(g.item())\n",
    "    #print(torch.norm(torch.autograd.grad(g, params, create_graph=True)[0]))\n",
    "    \n",
    "    return [params[0] - alpha * torch.autograd.grad(g, params, create_graph=True)[0]]\n",
    "\n",
    "\n",
    "def regressor(params, Z, y):\n",
    "    w = params[0]\n",
    "    loss = (torch.norm(Z @ w - y))**2\n",
    "    return loss\n",
    "\n",
    "def inner_solver(hparams, steps=100, params0=None, optim=None): \n",
    "    \n",
    "    H = hparams[0] \n",
    "    Zg = Xg @ H\n",
    "    \n",
    "    # params = [torch.randn(d).requires_grad_(True)]\n",
    "    params = [p.requires_grad_(True) for p in p0]\n",
    "\n",
    "    for _ in range(steps):\n",
    "        \n",
    "        loss = 0.5 * regressor(params, Zg, yg) / n + 0.5 * b * (torch.norm(params[0]))**2 \n",
    "        params = [params[0] - alpha * torch.autograd.grad(loss, params, create_graph=True)[0]]\n",
    "\n",
    "    return params\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ESJ"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (2.68e-02s)(1.50e-02, 1.15e-02) | val loss=508.63787841796875 | hypergrad norm = 3.846e+02\n",
      "outer step=10 (1.24e-02s)(5.84e-03, 6.48e-03) | val loss=5.404389381408691 | hypergrad norm = 4.147e+01\n",
      "outer step=20 (1.24e-02s)(5.87e-03, 6.45e-03) | val loss=1.799858570098877 | hypergrad norm = 2.228e+01\n",
      "outer step=30 (1.23e-02s)(5.83e-03, 6.41e-03) | val loss=0.8003532290458679 | hypergrad norm = 1.551e+01\n",
      "outer step=40 (1.27e-02s)(6.08e-03, 6.50e-03) | val loss=0.4041121006011963 | hypergrad norm = 1.069e+01\n",
      "outer step=50 (1.22e-02s)(5.77e-03, 6.36e-03) | val loss=0.15592409670352936 | hypergrad norm = 6.964e+00\n",
      "outer step=60 (1.32e-02s)(6.19e-03, 6.88e-03) | val loss=0.07211922109127045 | hypergrad norm = 4.388e+00\n",
      "outer step=70 (1.23e-02s)(5.77e-03, 6.38e-03) | val loss=0.05698142200708389 | hypergrad norm = 3.972e+00\n",
      "outer step=80 (1.36e-02s)(6.53e-03, 6.83e-03) | val loss=0.0313570573925972 | hypergrad norm = 2.883e+00\n",
      "outer step=90 (1.27e-02s)(5.90e-03, 6.68e-03) | val loss=0.01702926680445671 | hypergrad norm = 1.925e+00\n",
      "outer step=99 (1.30e-02s)(6.12e-03, 6.77e-03) | val loss=0.015844596549868584 | hypergrad norm = 1.786e+00\n",
      "total time = 1.2902510166168213\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 100\n",
    "eval_interval = 10\n",
    "T = 20\n",
    "mu = .01\n",
    "beta = 0.05\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time, hg_norms = 0,  [], [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.hgvzoj(params, hparams, outer_func, inner_solver, mu=mu, T=T, p=1, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "    hg_norms.append(torch.norm(hparams[0].grad))\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "        \n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "norm_zoj = hg_norms\n",
    "val_zoj = val_losses\n",
    "run_zoj = running_time\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# HOZOG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (2.73e-02s)(1.60e-02, 1.09e-02) | val loss=508.63787841796875 | hypergrad norm = 5.991e+00\n",
      "outer step=10 (1.18e-02s)(5.46e-03, 6.18e-03) | val loss=263.1659240722656 | hypergrad norm = 2.197e-01\n",
      "outer step=20 (1.20e-02s)(5.57e-03, 6.33e-03) | val loss=158.34835815429688 | hypergrad norm = 1.239e+00\n",
      "outer step=30 (1.16e-02s)(5.42e-03, 6.12e-03) | val loss=97.60418701171875 | hypergrad norm = 9.819e-01\n",
      "outer step=40 (1.27e-02s)(5.96e-03, 6.62e-03) | val loss=55.12971496582031 | hypergrad norm = 1.141e-01\n",
      "outer step=50 (1.23e-02s)(5.77e-03, 6.43e-03) | val loss=42.52833557128906 | hypergrad norm = 4.253e-01\n",
      "outer step=60 (1.24e-02s)(5.92e-03, 6.36e-03) | val loss=36.85363006591797 | hypergrad norm = 1.888e-01\n",
      "outer step=70 (1.21e-02s)(5.60e-03, 6.36e-03) | val loss=30.254831314086914 | hypergrad norm = 3.529e-02\n",
      "outer step=80 (1.33e-02s)(5.91e-03, 7.01e-03) | val loss=22.7914981842041 | hypergrad norm = 1.152e-01\n",
      "outer step=90 (1.30e-02s)(5.95e-03, 6.82e-03) | val loss=18.630878448486328 | hypergrad norm = 5.251e-01\n",
      "outer step=99 (1.39e-02s)(6.49e-03, 7.25e-03) | val loss=14.164862632751465 | hypergrad norm = 2.451e-02\n",
      "total time = 1.2642197608947754\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 100\n",
    "eval_interval = 10\n",
    "T = 20\n",
    "mu = 0.01\n",
    "beta = 0.1 # works better than 0.05\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time, hg_norms = 0,  [], [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.hozog(params, hparams, outer_func, inner_solver, mu=mu, T=T, p=1, params0=None, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "    hg_norms.append(torch.norm(hparams[0].grad))\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "\n",
    "\n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "norm_hozog = hg_norms\n",
    "val_hozog = val_losses\n",
    "run_hozog = running_time\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# AID-FP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (2.85e-02s)(1.39e-02, 1.43e-02) | val loss=508.63787841796875 | hypergrad norm = 2.435e+02\n",
      "outer step=10 (1.43e-02s)(5.74e-03, 8.48e-03) | val loss=10.422019004821777 | hypergrad norm = 1.657e+01\n",
      "outer step=20 (1.44e-02s)(5.73e-03, 8.54e-03) | val loss=3.3422141075134277 | hypergrad norm = 9.267e+00\n",
      "outer step=30 (1.42e-02s)(5.71e-03, 8.42e-03) | val loss=1.3675627708435059 | hypergrad norm = 4.755e+00\n",
      "outer step=40 (1.48e-02s)(6.01e-03, 8.69e-03) | val loss=0.7099817395210266 | hypergrad norm = 2.909e+00\n",
      "outer step=50 (1.45e-02s)(5.84e-03, 8.48e-03) | val loss=0.3342486023902893 | hypergrad norm = 1.416e+00\n",
      "outer step=60 (1.43e-02s)(5.70e-03, 8.44e-03) | val loss=0.22853609919548035 | hypergrad norm = 1.001e+00\n",
      "outer step=70 (1.42e-02s)(5.70e-03, 8.35e-03) | val loss=0.1534302979707718 | hypergrad norm = 6.573e-01\n",
      "outer step=80 (1.42e-02s)(5.70e-03, 8.39e-03) | val loss=0.11572474986314774 | hypergrad norm = 3.780e-01\n",
      "outer step=90 (1.42e-02s)(5.66e-03, 8.41e-03) | val loss=0.09151700884103775 | hypergrad norm = 1.996e-01\n",
      "outer step=99 (1.43e-02s)(5.73e-03, 8.47e-03) | val loss=0.07729817181825638 | hypergrad norm = 1.720e-01\n",
      "total time = 1.4730751514434814\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 100\n",
    "eval_interval = 10\n",
    "T = 20\n",
    "beta = 0.05\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time, hg_norms = 0,  [], [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.fixed_point(params, hparams, T, map_func, outer_func, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "    hg_norms.append(torch.norm(hparams[0].grad))\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "        \n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "norm_fp = hg_norms\n",
    "val_fp = val_losses\n",
    "run_fp = running_time\n",
    "    \n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# AID-CG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (3.36e-02s)(1.68e-02, 1.65e-02) | val loss=508.63787841796875 | hypergrad norm = 2.183e+02\n",
      "outer step=10 (1.53e-02s)(5.78e-03, 9.46e-03) | val loss=7.099592208862305 | hypergrad norm = 2.272e+00\n",
      "outer step=20 (1.52e-02s)(5.75e-03, 9.37e-03) | val loss=2.264677047729492 | hypergrad norm = 6.497e-01\n",
      "outer step=30 (1.51e-02s)(5.69e-03, 9.29e-03) | val loss=0.9662903547286987 | hypergrad norm = 2.882e-01\n",
      "outer step=40 (1.57e-02s)(6.01e-03, 9.56e-03) | val loss=0.45868730545043945 | hypergrad norm = 1.260e-01\n",
      "outer step=50 (1.51e-02s)(5.72e-03, 9.29e-03) | val loss=0.2504042685031891 | hypergrad norm = 8.133e-02\n",
      "outer step=60 (1.52e-02s)(5.73e-03, 9.34e-03) | val loss=0.1522390991449356 | hypergrad norm = 4.439e-02\n",
      "outer step=70 (1.51e-02s)(5.69e-03, 9.30e-03) | val loss=0.11653198301792145 | hypergrad norm = 2.831e-02\n",
      "outer step=80 (1.52e-02s)(5.74e-03, 9.33e-03) | val loss=0.09145060181617737 | hypergrad norm = 1.905e-02\n",
      "outer step=90 (1.53e-02s)(5.71e-03, 9.45e-03) | val loss=0.07671532034873962 | hypergrad norm = 1.540e-02\n",
      "outer step=99 (1.52e-02s)(5.74e-03, 9.38e-03) | val loss=0.06650297343730927 | hypergrad norm = 1.276e-02\n",
      "total time = 1.566755771636963\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 100\n",
    "eval_interval = 10\n",
    "T = 20\n",
    "beta = 0.05\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time, hg_norms = 0,  [], [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.CG(params, hparams, T, map_func, outer_func, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "    hg_norms.append(torch.norm(hparams[0].grad))\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "\n",
    "\n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "norm_cg = hg_norms\n",
    "val_cg = val_losses\n",
    "run_cg = running_time\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA6AAAAH6CAYAAAAZTyEJAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJzs3Xd8VFX+//HXmfSekISOQMBFQRQUEBQF9KuioKIU0VVWRaysgqy6uwqL/sQuoBRZVwQLIlJtiBRFkC4WiiAqBAghCoQUQkLa/f0xk5kJpLeZJO/n45FH7j1zzp3P5BoefnLOPR9jWRYiIiIiIiIi1c3m6QBERERERESkflACKiIiIiIiIjVCCaiIiIiIiIjUCCWgIiIiIiIiUiOUgIqIiIiIiEiNUAIqIiIiIiIiNUIJqIiIiIiIiNQIJaAiIiIiIiJSI5SAioiIiIiISI3w9XQAdUFMTIzVqlUrT4dRZ2RkZBASEuLpMATdC2+ie+E9dC+8h+6Fd9H98B66F96jPt2LrVu3HrUsK7a0fkpAq0CrVq347rvvPB1GnbF69Wp69+7t6TAE3QtvonvhPXQvvIfuhXfR/fAeuhfeoz7dC2PM/rL00xJcERERERERqRFKQEVERERERKRGKAEVERERERGRGqEEVERERERERGqEElARERERERGpEUpARUREREREpEYoARUREREREZEaoQRUREREREREaoQSUBEREREREakRSkBFRERERESkRigBFRERERERkRqhBFRERERERERqhBJQERERERERqRG+ng5ARERERKQ4eXl5pKWlkZ6eTmZmJvn5+Z4OyetFRESwa9cuT4chePe9sNlsBAUFERYWRnh4OD4+PjXyvkpARURERMQrZWdns3//foKDg4mMjKRZs2bYbDaMMZ4Ozaulp6cTFhbm6TAE770XlmWRn59PRkYG6enpHD16lJYtW+Lv71/t760EtA6zUhMwfsEQ3MB+blll+ge7rP1EREREqkteXh779+8nJiaGqKgoT4cjUqcYY/Dx8SE8PJzw8HCOHz/O/v37iYuLq/aZUCWgddC/Fm0naN9yHk6bSN6p8zhxuAnZ+/fT4I47iB5+d5FjNh3exKyds4hPjefy5pfz74v/XcNRi4iIiLikpaURHBys5FOkBkRFRXHy5EnS0tKq/XdO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yWfDhg1ZsGABfn5+Z/TbtWsX1113HRkZGQD069ePN998k6ZNm57R9+WXX+app57ilVdeIT8/n9GjRxMdHc0dd9xRbByPPPII06dPByAgIIDnnnuOBx98kMDA4lcD/vLLL0yaNImZM2eW6zN7ip4BrYeC/H1oGhEEwMHgaGd79gEPJ6AOJ8Lawj0r4bpXICDC9cKOhTC1K2x6U7VDRURERGq548ePc9tttzmTz4cffpi33367yOQTICIigrfeeouHH34YsD8jedttt5GSklKpOJYvX864ceMA8PHx4cMPP6R58+Zn9MvNzWXIkCHO5PPmm29myZIlRSafYE8gx40bx8SJE51tDzzwAHv37i2y//z5853JZ2BgIKtWreLRRx8tMfkEaNeuHTNmzGDz5s107Nix9A/sYUpA66k2DYsqxZJE/qlTxY5pFd7KeRyfGk9edSaBNh/oNsJeO7TjEFf7qTT44jH43xVw6Pvqe38RERERqVbTpk0jKSkJgPPPP59XXnmlTONeeeUVZ6J1+PBhZ9JWEfHx8YWS4BdeeIE+ffoU2ffDDz9kx44dADRp0oSZM2fi61v6gtLRo0fTt29fADIyMnjhhRfO6JOfn+9MggFefPFFLr300nJ9ls6dOzN8+PByjfEEJaD1VFyMqxRLVlSsvdGySizFEhEQQXSgfcY0Oz+bxIzEao+TsEYw8H8w7BOIPtvVfvhHexL6+RjIrNxfvURERESkZlmWxdSpU53nTz31VJFLXovi5+fHU0895TyfMmUKVgVK+GVlZTFw4ECOHTsGwKBBg/jHP/5RbP/XX3/deTx69OhiZ2qL8vTTTzuP3333XefzowWWLVvG7t27AWjUqBH3339/ma9d2ygBrafaxLp2wj0W6dopy+PPgRYnrhc8sA6ueAp8C5YhWLDlLfuy3G0fqXaoiIiISC2xbds2/vjDXv0gLCys3M9s3nTTTYSFhQH2HWG3b99e7hgeeOABvv/evqLu3HPP5e233y62b0pKClu3bnWel/QcZ1G6detGu3btADh16hRr164t9PqKFSucx0OGDMHf379c169NlIDWU21iXTvhJgTHOI/LUoqlQI0moAC+AXD5Y/DgRmh7las9409YNALevQGO/lqzMYmIiIhIua1fv9553KVLlzLPfhbw8/PjoosuKvJ6ZfHGG28we/ZswJ4AL1q0yJnQ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v534N3644ofUxeoAMNZyVGw0X6v4MDNrcolu2Eh040ZiGzbgNjV1uC+3tpbmV16h+ZU2gWlxcbugNDxzBsFRoxSYioiIiEivUwAq0kdOmVbB49e+h18/v4nbl6wnEnexFn6/fBv/eHM317//aD44d3yXgZ4xhgunX8ip407luy9/l6e3PY01hnfCVXy24ZdceOSF/Pvl/49x4RKstSR27SK6YYMflG4gumEDsQ0bcRsbO9y/W1dH86uv0vzqq63SnaIico89loJRI2kqKiLvuOMwOTm9+vmIiIiIyPCjAFSkD+UEHb501gwunD2Obz36Fkve9Z6MW9UY42t/eo0/rdrOdy+exYxRRV3uZ0TeCG5ZeAv/2PoPvr/8+1RHvCfhPrrxUV7c8SI3nHID7538XkLjxhEaN47CM85Il7XWkti92wtKN2wgutELSqMbNuA2dPzeUre+nqaXX6YQ2Pro3zC5ueTPm0v+SSeTf9JJ5B03CxPqugdXRERERKQtBaAi/WBieT53XzGff7y1h2//7S121Xrv93x5UzXn3fY8V50xjavPmkleTqDTfRhjWDxlMSePOZkfrPgBj29+HICqSBVfXfpVzp18Lt88+ZtU5FW0KxcaO5bQ2LEUvuf0dLq1lsTevUTXbyC2cUNLgLphA259fat92EiExpeW0fjSMm+f+fnkz5tH/kknUXDySeQeeywmqF8nIiIiItI1/cco0k+MMSyeNYb3zBzBbU+v5+4XNpN0LfGk5efPbOTR13bynQtncdZRo7rcT1luGT8844csnrKY/375v9nXvA+Af279Jyt2r+C6k67j/Knnd3sPpzGG0OjRhEaPhtNPS6enekybVq1i4yOPULy9kvi2ba3K2qYmGl94gcYXXmAf4OTnkzf/BApO9npIc48+WgGpiIiIiLSj/xBF+llBOMg3z/fu/7z+L2+w2n936PbqZj5130rmTirl9BkjOGVaBSdMLiM31HGv6FmTzuKEMSdw08qb+MuGvwBQE63huuev44nNT3D9KdczpmDMQdcv1WNacsEF1BUVMW/hQuI7d9K4YgVNK1bStHw58R07WpVxm5pofO55Gp97HgCnsJD8E04g/+STyT/5JHKPOgoT6Lx3V0RERESGBwWgIgPk6LHFPPT5U/nTqu384Il3qWnyXvr56rYaXt1Ww+1LNpATcJgzqZRTplWw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\n",
      "text/plain": [
       "<Figure size 1080x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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X/9i0qRJREVFHVP22Wef5b777mPatGkcOnSI4cOH07Jly1KH+A4dOtSrOMaNG+dOPlu1asX8+fMJDAw8ptymTZu48MILyc3NBeCiiy7ilVdeoW3btseUnTBhAo888ggTJ06ksLCQkSNHEhMTw7XXXltmHHfffTcvvfQSAMHBwTz55JPcfvvtNG3atMw6v/zyC8899xzTpk3z6pl9RV1c4pZQbD9QzQMVERERkdqzb98+rr76anfyedddd/H666+XmnwCREZG8tprr3HXXXcBzjmSV199NZmZ1VtAc8mSJYwZMwaAgIAA5syZQ/v27Y8pd+TIEa644gp38vmPf/yDRYsWlZp8gjOBHDNmDJMmTXL/9u9//5vk5ORSy8+bN8+dfDZt2pSlS5dy7733lpt8Apxyyim8/PLLrFmzhq5du1b8wD6mBFTcEuKPLkS0Ojndh5GIiIiISEM3ZcoU0tLSADj99NOZOHFipepNnDjRnWjt2rXLnbRVRWpqarEk+Omnn2bgwIGllp0zZw4//vgjAG3atGHatGk0aVLxgNKRI0cyePBgAHJzc3n66aePKVNYWOhOggHGjx9Pv379vHqWbt26ceONN3pVxxeUgIqbZw/ouq37OFJQ6MNoRERERKShstby4osvus8feeSRUoe8liYwMJBHHnnEfT558mSstV7HcOjQIS677DLS050dL8OGDWPUqFFlln/hhRfcxyNHjiyzp7Y0jz32mPv4zTffdM8fLfLJJ5+wefNmAGJjY7ntttsqfe/6RgmouLVvHkLbSGcX/4G8An7cme3jiERERESkIdqwYQO7d+8GIDw83Os5m5deeinh4eGAc0XYjRs3eh3Dv//9b7777jsATj31VF5//fUyy2ZmZrJu3Tr3eXnzOEvTq1cvTjnlFAAOHz7M119/Xez6Z5995j6+4oorCAoK8ur+9YkSUHEzxhQbhpukYbgiIiIiUgtWrlzpPu7Ro0elez+LBAYGctZZZ5V6v8qYOnUqM2bMAJwJ8IIFC9wJbWlWrVrlHqbboUMHWrdu7VV7AH369Ckz3hUrVpRariHSKrhSTEKHaBau3wE4FyK6tf+JPo5IREREpAJjI30dge+MzarT5owxNXKf7du3u4+Lega9dcopp7Bs2TIAduzYUel6q1evLrYdyvTp0+nUqVO5dWoq3iIl4925c6f7OD4+vkr3ry/UAyrFePaAfpuSQUGh9+PpRURERETKk5FxdMcFb+ZSevKsVzSPsyJ79uxh2LBh5OXlAXD//fdz2WWXVVivtuP1PK/o/jfddBPGmDI/qampVYqvrqgHVIqJi2lGq/Bg9uQcJufwETbtyqZLu0b8r4oiIiIi4rZw4cJKlfvxxx8ZPXp0rcbi7cJDRduoFPU+Dhw4kKeeeqo2QitVVRZKaoiUgEoxRfNAP/jBOQwgKSVDCaiIiIj4tzoehtqYVXaxoIp68aKjj+6+UNV9PLOyjr73mJiYcko6PfDAA3z11VcAtG/fnrlz5xIQEFCptmo73piYGHdiXNH977jjDoYMGVLst0ceeYSffvqpSnHVNQ3BlWP08tiORQsRiYiIiEhNa9++vfv4119/rdI9POu1a9eu3LJz587lueeeAyAoKIj58+fTsmXLSrdV2/G2bdvWfZycnFzufc4880yGDh1a7NOiRYsqxeQLSkDlGL09EtA1qRkUah6oiIiIiNSgvn37uo/Xrl1Lfn6+V/Xz8/OLbYvSr1+/Msv+9NNP3Hjjje7zF154gYSEBK/a69OnDw6HM3VKTk52byHjjVWrVrmPS8breb569Wqv712fKAGVY3RsFUZMqHPvocwD+fy6J8fHEYmIiIhIQ9K1a1diY2MByM7O5v333/eq/qJFi8jOdu5Z37p1a7p06VJquaysLC699FJyc3MBuP7667n11lu9jjcqKqrYti8zZ870qv63337L5s2bAQgODuYvf/lLsevnn3+++/idd97xOiGvT5SAyjGMMSWG4WaUU1pERERExDsOh4M77rjDff7EE09w5MiRStU9cuQI48aNc5/feeedpW4PY60lMTGR3377DYBu3boxderUKsd81113uY8nTZpUbE5nRcaOHes+TkxMPGaO7ODBg91bwaSlpfHKK69UOU5/pwRUSpXgOQw3RQmoiIiIiNSsESNG0Lp1awC+//57HnjggUrV+89//sMPP/wAQJs2bbj99ttLLTdu3Dh3z2p0dDQLFiygadOmVY53+PDhdO7cGXDu23nzzTdTUFBQYb0XXniBxYsXAxAaGsqDDz54TBmHw8Hjjz/uPr///vsb7FBcJaBSql4djq7MlZSSrmWjRURERKRGNW/enLfffts9t/K5557j5ptvLrNnMTs7m1tvvZVJkyYBzqRt1qxZpa64++mn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\n",
      "text/plain": [
       "<Figure size 1080x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "s, s2 = 20, 30 \n",
    "lw = 3\n",
    "\n",
    "plt.plot(run_zoj[:s2], val_zoj[:s2], '-', label='ESJ', linewidth=lw)\n",
    "plt.plot(run_hozog[:s2], val_hozog[:s2], '-', label='HOZOG', linewidth=lw)\n",
    "plt.plot(run_cg[:s], val_cg[:s], '-', label='AID-CG', linewidth=lw)\n",
    "plt.plot(run_fp[:s], val_fp[:s], '-', label='AID-FP', linewidth=lw)\n",
    "plt.xlabel('Running time', fontsize=24)\n",
    "plt.ylabel('Outer loss', fontsize=24)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.grid()\n",
    "plt.legend(loc='upper right', fontsize=30)\n",
    "plt.gcf().set_size_inches(15, 8)\n",
    "#plt.savefig('hrl_T20.pdf', bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "plt.plot(run_zoj[:s2], norm_zoj[:s2], '-', label='ESJ', linewidth=lw)\n",
    "plt.plot(run_hozog[:s2], norm_hozog[:s2], '-', label='HOZOG', linewidth=lw)\n",
    "plt.plot(run_cg[:s], norm_cg[:s], '-', label='AIG-CG', linewidth=lw)\n",
    "plt.plot(run_fp[:s], norm_fp[:s], '-', label='AID-FP', linewidth=lw)\n",
    "\n",
    "plt.xlabel('Running time', fontsize=24)\n",
    "plt.ylabel('Hypergradient norm', fontsize=24)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.legend(loc='upper right', fontsize=30) #'lower right'\n",
    "plt.grid()\n",
    "plt.gcf().set_size_inches(15, 8)\n",
    "#plt.savefig('hrl_grad.pdf', bbox_inches='tight', transparent=True, dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Higher Dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "p, d, n = 128, 256, 1000\n",
    "m = 0.1 \n",
    "\n",
    "H_true = torch.randn((p, d))\n",
    "w_true = torch.randn(d)\n",
    "Xg = torch.randn((n, p))\n",
    "yg = Xg @ H_true @ w_true + m * torch.randn(n)\n",
    "Xf = torch.randn((n, p))\n",
    "yf = Xf @ H_true @ w_true + m * torch.randn(n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "b = 0.1\n",
    "\n",
    "def inner_func(params, hparams):\n",
    "    H = hparams[0]\n",
    "    w = params[0]\n",
    "    \n",
    "    g =  (0.5 * (torch.norm(Xg @ H @ w - yg))**2) / n + 0.5 * b * (torch.norm(w))**2 \n",
    "    return g #.squeeze()\n",
    "\n",
    "def outer_func(params, hparams):\n",
    "    \n",
    "    H = hparams[0]\n",
    "    w = params[0]\n",
    "    \n",
    "    f = (0.5 * (torch.norm(Xf @ H @ w - yf))**2) / n \n",
    "    \n",
    "    return f #.squeeze()\n",
    "\n",
    "alpha = .001\n",
    "p0 = [torch.randn(d)]\n",
    "hp0 = [torch.randn((p, d))]\n",
    "\n",
    "def map_func(params, hparams):\n",
    "    \n",
    "    g = inner_func(params, hparams)\n",
    "    #inner_losses.append(g.item())\n",
    "    #print(torch.norm(torch.autograd.grad(g, params, create_graph=True)[0]))\n",
    "    \n",
    "    return [params[0] - alpha * torch.autograd.grad(g, params, create_graph=True)[0]]\n",
    "\n",
    "\n",
    "def regressor(params, Z, y):\n",
    "    w = params[0]\n",
    "    loss = (torch.norm(Z @ w - y))**2\n",
    "    return loss\n",
    "\n",
    "def inner_solver(hparams, steps=100, params0=None, optim=None): \n",
    "    \n",
    "    H = hparams[0] \n",
    "    Zg = Xg @ H\n",
    "    \n",
    "    # params = [torch.randn(d).requires_grad_(True)]\n",
    "    params = [p.requires_grad_(True) for p in p0]\n",
    "\n",
    "    for _ in range(steps):\n",
    "        \n",
    "        loss = 0.5 * regressor(params, Zg, yg) / n + 0.5 * b * (torch.norm(params[0]))**2 \n",
    "        params = [params[0] - alpha * torch.autograd.grad(loss, params, create_graph=True)[0]]\n",
    "\n",
    "    return params\n",
    "\n",
    "\n",
    "# def inner_solver(hparams, steps=100, params0=None, optim=None):\n",
    "\n",
    "#     # params = [torch.randn(d).requires_grad_(True)]\n",
    "#     params = [p.requires_grad_(True) for p in p0]\n",
    "\n",
    "#     for _ in range(steps):\n",
    "#         params = map_func(params, hparams)\n",
    "\n",
    "#     return params\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ESJ"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (6.86e-02s)(3.77e-02, 3.04e-02) | val loss=1197.4111328125 | hypergrad norm = 8.699e+02\n",
      "outer step=10 (2.80e-02s)(1.30e-02, 1.48e-02) | val loss=8.839682579040527 | hypergrad norm = 6.224e+01\n",
      "outer step=20 (2.82e-02s)(1.30e-02, 1.49e-02) | val loss=2.408905029296875 | hypergrad norm = 3.425e+01\n",
      "outer step=30 (2.80e-02s)(1.30e-02, 1.48e-02) | val loss=0.8888125419616699 | hypergrad norm = 2.023e+01\n",
      "outer step=40 (2.80e-02s)(1.30e-02, 1.48e-02) | val loss=0.38051822781562805 | hypergrad norm = 1.301e+01\n",
      "outer step=50 (2.80e-02s)(1.29e-02, 1.48e-02) | val loss=0.2949046492576599 | hypergrad norm = 1.196e+01\n",
      "outer step=60 (2.79e-02s)(1.29e-02, 1.47e-02) | val loss=0.23724213242530823 | hypergrad norm = 1.098e+01\n",
      "outer step=70 (2.81e-02s)(1.30e-02, 1.49e-02) | val loss=0.4177219271659851 | hypergrad norm = 1.435e+01\n",
      "outer step=80 (2.80e-02s)(1.30e-02, 1.48e-02) | val loss=1.9105294942855835 | hypergrad norm = 3.294e+01\n",
      "outer step=90 (2.79e-02s)(1.29e-02, 1.48e-02) | val loss=0.6200764775276184 | hypergrad norm = 1.843e+01\n",
      "outer step=100 (2.81e-02s)(1.31e-02, 1.48e-02) | val loss=0.26972267031669617 | hypergrad norm = 1.180e+01\n",
      "outer step=110 (2.80e-02s)(1.29e-02, 1.48e-02) | val loss=0.13050037622451782 | hypergrad norm = 8.230e+00\n",
      "outer step=120 (2.79e-02s)(1.30e-02, 1.47e-02) | val loss=0.1024964302778244 | hypergrad norm = 7.155e+00\n",
      "outer step=130 (2.80e-02s)(1.30e-02, 1.48e-02) | val loss=0.07978766411542892 | hypergrad norm = 6.047e+00\n",
      "outer step=140 (2.81e-02s)(1.30e-02, 1.49e-02) | val loss=0.036162905395030975 | hypergrad norm = 4.045e+00\n",
      "outer step=149 (2.79e-02s)(1.29e-02, 1.48e-02) | val loss=0.3495720326900482 | hypergrad norm = 1.425e+01\n",
      "total time = 4.277534008026123\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 150\n",
    "eval_interval = 10\n",
    "T = 20\n",
    "#K = 10 \n",
    "mu = .01\n",
    "beta = 0.05\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time = 0,  [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.hgvzoj(params, hparams, outer_func, inner_solver, mu=mu, T=T, p=1, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "        \n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "val_zoj = val_losses\n",
    "run_zoj = running_time\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# HOZOG "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (7.58e-02s)(4.00e-02, 3.53e-02) | val loss=1197.4111328125 | hypergrad norm = 7.935e-01\n",
      "outer step=10 (2.79e-02s)(1.29e-02, 1.47e-02) | val loss=523.5926513671875 | hypergrad norm = 4.828e+00\n",
      "outer step=20 (2.79e-02s)(1.30e-02, 1.47e-02) | val loss=185.0880584716797 | hypergrad norm = 1.591e+00\n",
      "outer step=30 (2.80e-02s)(1.30e-02, 1.47e-02) | val loss=99.13282775878906 | hypergrad norm = 1.877e-01\n",
      "outer step=40 (2.79e-02s)(1.30e-02, 1.47e-02) | val loss=63.260467529296875 | hypergrad norm = 3.010e-01\n",
      "outer step=50 (2.79e-02s)(1.30e-02, 1.47e-02) | val loss=48.292152404785156 | hypergrad norm = 5.878e-01\n",
      "outer step=60 (2.75e-02s)(1.30e-02, 1.43e-02) | val loss=38.41683578491211 | hypergrad norm = 5.302e-02\n",
      "outer step=70 (2.66e-02s)(1.25e-02, 1.39e-02) | val loss=33.170833587646484 | hypergrad norm = 2.548e-01\n",
      "outer step=80 (2.66e-02s)(1.25e-02, 1.39e-02) | val loss=29.22417640686035 | hypergrad norm = 1.431e-01\n",
      "outer step=90 (2.67e-02s)(1.25e-02, 1.39e-02) | val loss=23.805339813232422 | hypergrad norm = 1.781e-01\n",
      "outer step=100 (2.67e-02s)(1.25e-02, 1.39e-02) | val loss=19.665494918823242 | hypergrad norm = 6.542e-02\n",
      "outer step=110 (2.67e-02s)(1.26e-02, 1.39e-02) | val loss=16.744539260864258 | hypergrad norm = 1.080e-01\n",
      "outer step=120 (3.18e-02s)(1.44e-02, 1.72e-02) | val loss=14.831977844238281 | hypergrad norm = 1.195e-01\n",
      "outer step=130 (2.91e-02s)(1.32e-02, 1.56e-02) | val loss=13.956759452819824 | hypergrad norm = 7.296e-02\n",
      "outer step=140 (2.89e-02s)(1.31e-02, 1.55e-02) | val loss=12.396344184875488 | hypergrad norm = 1.173e-02\n",
      "outer step=149 (2.67e-02s)(1.26e-02, 1.39e-02) | val loss=11.22706413269043 | hypergrad norm = 1.114e-01\n",
      "total time = 4.219234466552734\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 150\n",
    "eval_interval = 10\n",
    "T = 20\n",
    "#K = 10 \n",
    "mu = 0.01\n",
    "beta = 0.1\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time = 0,  [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.hozog(params, hparams, outer_func, inner_solver, mu=mu, T=T, p=1, params0=None, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "\n",
    "\n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "val_hozog = val_losses\n",
    "run_hozog = running_time\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# AID-FP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (7.67e-02s)(3.89e-02, 3.74e-02) | val loss=1197.4111328125 | hypergrad norm = 5.186e+02\n",
      "outer step=10 (2.89e-02s)(1.30e-02, 1.58e-02) | val loss=17.918315887451172 | hypergrad norm = 2.187e+01\n",
      "outer step=20 (2.88e-02s)(1.30e-02, 1.56e-02) | val loss=4.412731170654297 | hypergrad norm = 1.144e+01\n",
      "outer step=30 (2.87e-02s)(1.29e-02, 1.56e-02) | val loss=1.5219109058380127 | hypergrad norm = 5.968e+00\n",
      "outer step=40 (2.87e-02s)(1.29e-02, 1.56e-02) | val loss=0.9506080150604248 | hypergrad norm = 3.715e+00\n",
      "outer step=50 (2.88e-02s)(1.29e-02, 1.56e-02) | val loss=0.6880261898040771 | hypergrad norm = 2.244e+00\n",
      "outer step=60 (2.76e-02s)(1.30e-02, 1.45e-02) | val loss=0.24693500995635986 | hypergrad norm = 1.342e+00\n",
      "outer step=70 (2.70e-02s)(1.25e-02, 1.43e-02) | val loss=0.15687395632266998 | hypergrad norm = 7.552e-01\n",
      "outer step=80 (2.70e-02s)(1.24e-02, 1.44e-02) | val loss=0.12205974757671356 | hypergrad norm = 6.044e-01\n",
      "outer step=90 (2.69e-02s)(1.24e-02, 1.43e-02) | val loss=0.09525397419929504 | hypergrad norm = 3.698e-01\n",
      "outer step=100 (2.70e-02s)(1.25e-02, 1.44e-02) | val loss=0.07939820736646652 | hypergrad norm = 2.148e-01\n",
      "outer step=110 (2.69e-02s)(1.24e-02, 1.42e-02) | val loss=0.0700264647603035 | hypergrad norm = 1.433e-01\n",
      "outer step=120 (2.69e-02s)(1.24e-02, 1.43e-02) | val loss=0.06311522424221039 | hypergrad norm = 9.312e-02\n",
      "outer step=130 (2.69e-02s)(1.24e-02, 1.43e-02) | val loss=0.05764485523104668 | hypergrad norm = 6.151e-02\n",
      "outer step=140 (2.69e-02s)(1.24e-02, 1.43e-02) | val loss=0.05312753841280937 | hypergrad norm = 3.960e-02\n",
      "outer step=149 (2.71e-02s)(1.25e-02, 1.44e-02) | val loss=0.04969889298081398 | hypergrad norm = 2.904e-02\n",
      "total time = 4.2472639083862305\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 150\n",
    "eval_interval = 10\n",
    "T = 20\n",
    "beta = 0.05\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time = 0,  [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.fixed_point(params, hparams, T, map_func, outer_func, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "        \n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "val_fp = val_losses\n",
    "run_fp = running_time\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# AID-CG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (7.73e-02s)(4.92e-02, 2.77e-02) | val loss=1197.4111328125 | hypergrad norm = 3.977e+02\n",
      "outer step=10 (2.89e-02s)(1.27e-02, 1.60e-02) | val loss=17.882030487060547 | hypergrad norm = 4.482e+00\n",
      "outer step=20 (2.87e-02s)(1.26e-02, 1.59e-02) | val loss=5.776135444641113 | hypergrad norm = 1.331e+00\n",
      "outer step=30 (2.92e-02s)(1.27e-02, 1.62e-02) | val loss=2.389629602432251 | hypergrad norm = 4.621e-01\n",
      "outer step=40 (2.93e-02s)(1.27e-02, 1.63e-02) | val loss=1.305540680885315 | hypergrad norm = 2.379e-01\n",
      "outer step=50 (2.76e-02s)(1.25e-02, 1.49e-02) | val loss=0.8788031935691833 | hypergrad norm = 1.592e-01\n",
      "outer step=60 (2.81e-02s)(1.30e-02, 1.49e-02) | val loss=0.6584704518318176 | hypergrad norm = 1.199e-01\n",
      "outer step=70 (2.69e-02s)(1.20e-02, 1.47e-02) | val loss=0.4949369430541992 | hypergrad norm = 8.541e-02\n",
      "outer step=80 (2.68e-02s)(1.20e-02, 1.47e-02) | val loss=0.3933676481246948 | hypergrad norm = 6.333e-02\n",
      "outer step=90 (2.77e-02s)(1.20e-02, 1.55e-02) | val loss=0.3318435847759247 | hypergrad norm = 5.278e-02\n",
      "outer step=100 (2.80e-02s)(1.25e-02, 1.53e-02) | val loss=0.2882140576839447 | hypergrad norm = 4.618e-02\n",
      "outer step=110 (2.69e-02s)(1.20e-02, 1.46e-02) | val loss=0.2518264651298523 | hypergrad norm = 3.996e-02\n",
      "outer step=120 (2.69e-02s)(1.20e-02, 1.47e-02) | val loss=0.2219531536102295 | hypergrad norm = 3.465e-02\n",
      "outer step=130 (2.67e-02s)(1.21e-02, 1.45e-02) | val loss=0.1983851194381714 | hypergrad norm = 3.076e-02\n",
      "outer step=140 (2.66e-02s)(1.19e-02, 1.45e-02) | val loss=0.17912206053733826 | hypergrad norm = 2.771e-02\n",
      "outer step=149 (2.67e-02s)(1.20e-02, 1.45e-02) | val loss=0.16424468159675598 | hypergrad norm = 2.527e-02\n",
      "total time = 4.248292446136475\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 150\n",
    "eval_interval = 10\n",
    "T = 20\n",
    "beta = 0.01 # diverges with 0.05\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time = 0,  [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.CG(params, hparams, T, map_func, outer_func, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "\n",
    "\n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "val_cg = val_losses\n",
    "run_cg = running_time\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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PWN6sirRnv65IXkDbRu1reGIxe80agHjl8CsiyE9EXKPw3uj4KZl0KKLr6MTERGRCvJONK+//voK7Sj7/vvvs2PHDjZv3symTZvo2bNnLUbo8cwzz7h3IO7WrRv9+/ev8r26du3KhRdeyJdffklubi5PPvkkL774YrXiGzp0KHFxcSQkJJCUlMTrr7/OXXfdVa171gdKUqVGxHqtS614GRpP4pGz/VesggL3ee+WvYskqX899a81FKn4tchT4LrFMPsSu0RNViq8MwJu/sJ+TkRERPza4cOH+fTTTwFo3Lgxr776KmFhYeX2a9asGRMnTgTsJLcuktQPP/yQZ5991n3+yCOP4HBUb6LpP//5T77++msKCgqYMWMG559/PqNHj65Q37179/Lyyy8XicnhcPDYY48xZoy9R8sDDzxA7969q5VM1wea7is1omMVytAERkcT6FqcbmVnk+u1KL13y6LrUuUkEhMH1y6E4Eb2eXqinager3pxbREREakb7733nntK6siRIyuUoAJcffXVBAba42fvv/8+ubm5tRZjUlIS999/P6NHj3ZP2b355psZO3Zste997rnn8vjjjwP2pkpjx45l6tSpZGSU/vtxZmYmzzzzDD179uSHH34o9vzo0aPdo6dZWVkMHjyY6dOnk52dXWYse/bsITGxfi6b00iq1IiitVIrVoYGIKRrHPmH7OQjOz4eIuz7nBl9JsGOYHKduexN28uhzEO0CG9R1q2kIWnbG8bOgTmj7fWpqb/Be1fCDZ/a61dFRETEL1V0V98TxcTEcNFFF7F06VJSUlL4+OOPGTVqVJViSEhIYMmSJe7z3Nxcjh49yr59+1i7di3ff/99kST4lltu4ZVXXqnSa5XkoYceIjs7m8ceewyn08k///lPXn75ZYYOHUq/fv1o0aIFTqeTpKQkVq9ezYoVK0hLSyvzntOnT8eyLF555RWys7OZNGkSTzzxBBdeeCH9+vUjOjqasLAw0tPT2bVrF6tWreK7774jPz8fgMjISMLDw8t8DX+iJFVqhHcZmj0pGTidFg5H+cWQQ+O6kvHd9wDkJCRAb3sENTggmO4tuvNj8o8AbDi4gaGxQ2shcvFbnQbBqDfhg/H2jr9JW+D9sTBunhJVERERP7Rx40a2bNkCQNu2bRk0aFCl+l933XUsXboUsJPdqiap8+fPZ/78+eW2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\n",
      "text/plain": [
       "<Figure size 1080x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "s, s2 = 25, 25\n",
    "lw = 3\n",
    "\n",
    "plt.plot(run_zoj[:s2], val_zoj[:s2], '-', label='ESJ', linewidth=lw)\n",
    "plt.plot(run_hozog[:s2], val_hozog[:s2], '-', label='HOZOG', linewidth=lw)\n",
    "plt.plot(run_cg[:s], val_cg[:s], '-', label='AID-CG', linewidth=lw)\n",
    "plt.plot(run_fp[:s], val_fp[:s], '-', label='AID-FP', linewidth=lw)\n",
    "plt.xlabel('Running time', fontsize=24)\n",
    "plt.ylabel('Outer loss', fontsize=24)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.grid()\n",
    "plt.legend(loc='upper right', fontsize=30)\n",
    "plt.gcf().set_size_inches(15, 8)\n",
    "# plt.savefig('hrl_T20_D256.pdf', bbox_inches='tight', transparent=True, dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Different number T of inner loop steps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (2.96e-02s)(1.64e-02, 1.26e-02) | val loss=508.63787841796875 | hypergrad norm = 3.846e+02\n",
      "outer step=10 (1.26e-02s)(5.79e-03, 6.74e-03) | val loss=5.386643886566162 | hypergrad norm = 4.129e+01\n",
      "outer step=20 (1.27e-02s)(5.81e-03, 6.76e-03) | val loss=1.8146494626998901 | hypergrad norm = 2.238e+01\n",
      "outer step=30 (1.25e-02s)(5.73e-03, 6.71e-03) | val loss=0.7977696061134338 | hypergrad norm = 1.537e+01\n",
      "outer step=40 (1.26e-02s)(5.76e-03, 6.71e-03) | val loss=0.40675872564315796 | hypergrad norm = 1.075e+01\n",
      "outer step=50 (1.24e-02s)(5.67e-03, 6.61e-03) | val loss=0.14815568923950195 | hypergrad norm = 6.738e+00\n",
      "outer step=60 (1.25e-02s)(5.73e-03, 6.69e-03) | val loss=0.07873979210853577 | hypergrad norm = 4.573e+00\n",
      "outer step=70 (1.23e-02s)(5.62e-03, 6.61e-03) | val loss=0.057468317449092865 | hypergrad norm = 3.979e+00\n",
      "outer step=80 (1.25e-02s)(5.76e-03, 6.67e-03) | val loss=0.028070863336324692 | hypergrad norm = 2.688e+00\n",
      "outer step=90 (1.24e-02s)(5.70e-03, 6.61e-03) | val loss=0.01711208000779152 | hypergrad norm = 1.918e+00\n",
      "outer step=99 (1.33e-02s)(6.34e-03, 6.80e-03) | val loss=0.014298493042588234 | hypergrad norm = 1.653e+00\n",
      "total time = 1.287309169769287\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 100\n",
    "eval_interval = 10\n",
    "T = 20\n",
    "mu = .01\n",
    "beta = 0.05\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time = 0,  [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.hgvzoj(params, hparams, outer_func, inner_solver, mu=mu, T=T, p=1, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "        \n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "val_zoj20 = val_losses\n",
    "run_zoj20 = running_time\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (1.88e-02s)(1.08e-02, 7.65e-03) | val loss=1155.5977783203125 | hypergrad norm = 5.728e+02\n",
      "outer step=10 (7.11e-03s)(2.98e-03, 4.02e-03) | val loss=22.412263870239258 | hypergrad norm = 8.318e+01\n",
      "outer step=20 (6.94e-03s)(2.92e-03, 3.92e-03) | val loss=9.328634262084961 | hypergrad norm = 5.384e+01\n",
      "outer step=30 (7.97e-03s)(3.18e-03, 4.62e-03) | val loss=3.784883499145508 | hypergrad norm = 3.114e+01\n",
      "outer step=40 (6.91e-03s)(2.92e-03, 3.89e-03) | val loss=1.3932955265045166 | hypergrad norm = 1.918e+01\n",
      "outer step=50 (6.90e-03s)(2.91e-03, 3.89e-03) | val loss=0.39852824807167053 | hypergrad norm = 1.022e+01\n",
      "outer step=60 (7.24e-03s)(2.89e-03, 4.24e-03) | val loss=0.14180555939674377 | hypergrad norm = 5.925e+00\n",
      "outer step=70 (6.91e-03s)(2.94e-03, 3.87e-03) | val loss=0.06238687410950661 | hypergrad norm = 4.113e+00\n",
      "outer step=80 (6.89e-03s)(2.90e-03, 3.89e-03) | val loss=0.029090922325849533 | hypergrad norm = 2.473e+00\n",
      "outer step=90 (7.09e-03s)(3.02e-03, 3.96e-03) | val loss=0.016166940331459045 | hypergrad norm = 1.833e+00\n",
      "outer step=99 (6.92e-03s)(2.92e-03, 3.90e-03) | val loss=0.00919819250702858 | hypergrad norm = 1.080e+00\n",
      "total time = 0.731717586517334\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 100\n",
    "eval_interval = 10\n",
    "T = 10\n",
    "mu = .01\n",
    "beta = 0.05\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time = 0,  [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.hgvzoj(params, hparams, outer_func, inner_solver, mu=mu, T=T, p=1, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "        \n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "val_zoj10 = val_losses\n",
    "run_zoj10 = running_time\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (4.21e-02s)(2.36e-02, 1.82e-02) | val loss=175.12783813476562 | hypergrad norm = 2.326e+02\n",
      "outer step=10 (2.48e-02s)(1.15e-02, 1.31e-02) | val loss=1.9239643812179565 | hypergrad norm = 2.321e+01\n",
      "outer step=20 (2.53e-02s)(1.22e-02, 1.29e-02) | val loss=0.6176621913909912 | hypergrad norm = 1.361e+01\n",
      "outer step=30 (2.51e-02s)(1.21e-02, 1.27e-02) | val loss=0.24652056396007538 | hypergrad norm = 8.091e+00\n",
      "outer step=40 (2.53e-02s)(1.23e-02, 1.29e-02) | val loss=0.08766528218984604 | hypergrad norm = 4.800e+00\n",
      "outer step=50 (2.52e-02s)(1.22e-02, 1.28e-02) | val loss=0.04506208002567291 | hypergrad norm = 3.476e+00\n",
      "outer step=60 (2.51e-02s)(1.22e-02, 1.27e-02) | val loss=0.03296581655740738 | hypergrad norm = 2.876e+00\n",
      "outer step=70 (2.56e-02s)(1.25e-02, 1.29e-02) | val loss=0.01167237013578415 | hypergrad norm = 1.310e+00\n",
      "outer step=80 (2.50e-02s)(1.16e-02, 1.32e-02) | val loss=0.00818544253706932 | hypergrad norm = 9.203e-01\n",
      "outer step=90 (2.49e-02s)(1.16e-02, 1.31e-02) | val loss=0.0064415400847792625 | hypergrad norm = 6.178e-01\n",
      "outer step=99 (2.38e-02s)(1.11e-02, 1.26e-02) | val loss=0.005805346183478832 | hypergrad norm = 4.693e-01\n",
      "total time = 2.4091451168060303\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "K = 100\n",
    "eval_interval = 10\n",
    "T = 40\n",
    "mu = .01\n",
    "beta = 0.05\n",
    "\n",
    "#hparams = [torch.randn((p, d)).requires_grad_(True)]\n",
    "hparams = [hp.clone() for hp in hp0]\n",
    "hparams = [hp.requires_grad_(True) for hp in hparams]\n",
    "\n",
    "outer_opt = torch.optim.Adam(lr=beta, params=hparams)\n",
    "\n",
    "total_time, val_losses, running_time = 0,  [], []\n",
    "\n",
    "for k in range(K):\n",
    "    \n",
    "    step_start_time = time.time() \n",
    "    inner_losses = []\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "    _, cost = hg.hgvzoj(params, hparams, outer_func, inner_solver, mu=mu, T=T, p=1, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "    val_losses.append(cost.item())\n",
    "    outer_opt.step()\n",
    "    \n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    running_time.append(total_time)\n",
    "\n",
    "    if k % eval_interval == 0 or k == K - 1:\n",
    "        print('outer step={} ({:.2e}s)({:.2e}, {:.2e}) | val loss={} | hypergrad norm = {:.3e}'.format(k, step_time, t1, t2, val_losses[-1], torch.norm(hparams[0].grad)))\n",
    "        \n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "#plt.plot(val_losses)\n",
    "plt.plot(running_time, val_losses)\n",
    "plt.show()\n",
    "\n",
    "val_zoj50 = val_losses\n",
    "run_zoj50 = running_time\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "#run_zoj5 = [t * 5 for t in run_zoj5]\n",
    "run_zoj10 = [t * 5 for t in run_zoj10]\n",
    "run_zoj20 = [t * 5 for t in run_zoj20]\n",
    "run_zoj50 = [t * 5 for t in run_zoj50]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA60AAAH6CAYAAADssaq5AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJzs3Xl81NW9//HXmWwkIRAICGENsioIESYqrlhRERSjDbTea3GjcFv51Xprf7et+rveW629Xq+tte5yXdCqgOwoYNTYKqAEQUAhETAJ+xqyEbLN+f0xw2SyZyDJTCbv5+ORx3yXc77zmRoonznnfI6x1iIiIiIiIiISjByBDkBERERERESkIUpaRUREREREJGgpaRUREREREZGgpaRVREREREREgpaSVhEREREREQlaSlpFREREREQkaClpFRERERERkaClpFVERERERESClpJWERERERERCVrhgQ4gFPTo0cMmJSUFOgwRCbCSkhJiY2MDHYaIiLQB/Z0vHVVDv/sbN248aq3t2RrvqaS1BSQlJZGZmRnoMEQkwDIyMpgwYUKgwxARkTagv/Olo2rod98Yk9ta76npwSIiIiIiIhK0lLSKiIiIiIhI0FLSKiIiIiIiIkFLSauIiIiIiIgELSWtIiIiIiIiErSUtIqIiIiIiEjQUtIqIiIiIiIiQUtJq4iIiIiIiAQtJa0iIiIiIiIStJS0ioiIiIiISNBS0ioiIiIiIiJBS0mriIiIiIiIBC0lrSIiIiIiIhK0lLSKiIiIiIhI0FLSKiIiIiIiIkFLSWsHUOWylFe6Ah2GiIiIiIiI35S0hrBlX+/njv/9kuT/WMOKLfsDHY6IiIiIiIjflLSGsJyjJXyafYSisko25OQHOhwRERERERG/KWkNYc6kbt7jjbnHAxiJiIiIiIjImVHSGsKS+8cT7jAAZB8q5sTJ8gBHJCIiIiIi4h8lrSEsJjKckX27es835mqKsIiIiIiItC9KWkNcysDqKcJa1yoiIiIiIu2NktYQ50zq7j3OzNG6VhERERERaV+UtIY432JMW/YWcKqiKoDRiIiIiIiI+EdJa4jr0TmKc3vEAlBe5WLrvoIARyQiIiIiItJ8Slo7AN/R1g2aIiwiIiIiIu2IktYOoOa6VhVjEhERERGR9kNJaweQUqsYk8tlAxiNiIiIiIhI8ylp7QCSEmLo0TkSgMJTlXx3uDjAEYmIiIiIiDSPktYOwBiDc2D1aKvWtYqIiIiISHuhpLWD8C3GpP1aRURERESkvVDS2kH4rmvdoGJMIiIiIiLSTgRl0mqMSTDGzDTGLDbG7DTGlBpjCowxnxlj7jHG1Bu3MeZSY8z7xpjjxpiTxpgtxphfGmPCGnmvG40xGZ7nFxtjvjDG3NF6ny4wzu/ThegI9/8M+06Usv9EaYAjEhERERERaVpQJq3ANOBl4GLgC+DPwHvAKOAVYL4xxvh2MMbcDPwduBJYDDwLRAJ/At6p702MMXOA5Z7nvul5zz7Aa8aYJ1v8UwVQRJiDCwfEe88zczXaKiIiIiIiwS9Yk9ZsYCrQz1r7z9ba31pr7wZGAHuAHwK3nm5sjOmCO+GsAiZYa++x1v4aSAbWAWnGmB/7voExJgl4EjgOOK2191pr7wdGA7uAXxljxrfux2xbzlpb34iIiIiIiAS7oExarbUfW2uXW2tdta4fBF7wnE7wuZUG9ATesdZm+rQ/BTzkOf1Zrbe5G4gC/mqtzfHpkw/8wXP6L2f3SYJLik8xJq1rFRERERGR9iAok9YmVHheK32u/cDzuqqe9n8HTgKXGmOimtnng1ptQsKFA7rh8Eyq3nGwkMJTFY13EBERERERCbB2lbQaY8KBGZ5T32RzuOc1u3Yfa20l8D0QDpzbzD4HgBKgnzEm5izDDhqdo8I5v08XAKyFr7SuVUREREREglx4oAPw0x9xF01631q72ud6V89rQQP9Tl+P97nWnD6xnnYna980xswCZgH06tWLjIyMpmIPConhZWzzHL/36WY4EBnQeERCSXFxcbv5u0BERM6O/s6XjioQv/vtJmk1xvwC+BWwA/iJv909r7al+lhrXwJeAnA6nXbChAl+hhQYJd0P8GHuVwActnFMmBBStaZEAiojI4P28neBiIicHf2dLx1VIH7328X0YGPMvcDTwLfA1dba2qVvT4+WdqV+XWq186dPoR+hBj2nTzGmzXtOUF7paqS1iIiIiIhIYAV90mqM+SXwV2Ab7oT1YD3Nsjyvw+rpHw4Mwl24aXcz+yTinhq811pbZ2pwe9arSycGdHcv0y2rdLFtf0Ozo0VERERERAIvqJNWY8y/AX8CNuNOWA830PRjz+ukeu5dCcQAa621Zc3sc0OtNiHFd7RV+7WKiIiIiEgwC9qk1RjzMO7CSxuBa6y1RxtpvhA4CvzYGOP0eUYn4FHP6fO1+rwKlAFzjDFJPn26Ab/znL5ACEpJ6u491n6tIiIiIiISzIKyEJMx5g7gP4Eq4B/AL4wxtZvlWGtfA7DWFhpjfoo7ec0wxrwDHAem4t7aZiHwrm9na+33xphfA38BMo0x7wLlQBrQD/gfa+261vmEgZVSa6TVWks9//uKiIiIiIgEXFAmrbjXoAKEAb9soM2nwGunT6y1S4wxVwEPAj8EOgE7gX8F/mKtrVMF2Fr7jDEmB3gA9/6vDtzFnh6y1r7eIp8kCA3u2ZluMRHkn6wg/2QFu46UMOSczoEOS0REREREpI6gTFqttY8Aj5xBv8+ByX72WQ4s9/e92jNjDOMGdid9+yHAPdqqpFVERERERIJR0K5pldblO0VY61pFRERERCRYKWntoJw+xZgyc1VBWEREREREgpOS1g5qVN8uRIW7//PnHjvJ4cJTAY5IRERERESkLiWtHVRUeBhj+sd7zzNzNUVYRERERESCj5LWDqzmulZNERYRERERkeCjpLUDq7GuVcWYREREREQkCClp7cDGDuiGMe7jb/YXUFxWGdiAREREREREalHS2oF1jY5geK84AFwWNuedCHBEIiIiIiIiNSlp7eBSfKYIa12riIiIiIgEGyWtHZzTpxiT9msVEREREZFgo6S1g/Mdad2Ud4KKKlcAoxEREREREalJSWsH1yc+mr7x0QCcLK9i+4HCAEckIiIiIiJSTUmr1JgivEFb34iIiIiISBBR0iq19mvVulYREREREQkeSlqFlFojrdbaAEYjIiIiIiJSTUmrMOycOOI6hQNwtLiM3GMnAxyRiIiIiIiIm5JWweEwOAf6jrZqirCIiIiIiAQHJa0C1F7XqmJMIiIiIiISHJS0CkDNkdZcjbSKiIiIiEhwUNIqAIzpH09EmAFg95ESjhWXBTgiERERERERJa3i0SkijAv6dvWeb8zVFGEREREREQk8Ja3ileK7rlVJq4iIiIiIBAElreLlW4xJFYRFRERERCQYKGkVr3E+xZi27SugtLwqgNGIiIiIiIgoaRUf3WMjGXJOZwAqqixf7z0R4IhERERERKSjU9IqNaQkVY+2ZmqKsIiIiIiIBJiSVqnBOdB3XauKMYmIiIiISGApaZUafCsIf5WbT5XLBjAaERERERHp6JS0Sg39u0dzTlwUAEVllWQdLApwRCIiIiIi0pEpaZUajDG19mvVulYREREREQkcJa1Sh9OnGJPWtYqIiIiISCApaZU6fEdaN3x/HGu1rlVERERERAJDSavUMaJ3HLGRYQAcLDzFvhOlAY5IREREREQ6KiWtUkd4mIOxA333a9UUYRERERERCQwlrVKvmvu1qhiTiIiIiIgEhpJWqVdKkkZaRUREREQk8JS0hqCjpUd5ecvLPPTZQ2f8jOQB8YQ5DABZh4ooOFnRUuGJiIiIiIg0m5LWEFNYXsik9ybxl01/YemupeQU5JzRc2IiwxnVp4v3fGOepgiLiIiIiEjbU9IaYrpEdmF8n/He84XZC8/4WU7frW80RVhERERERAJASWsImj5suvd4ya4llFWVndFzaq5r1UiriIiIiIi0PSWtIejSPpfSJ7YPAAVlBXyY++EZPWecTwXhr/cUcKqiqkXiExERERERaS4lrSEozBFG2rA07/mCrAVn9JyecVEM6hELQHmVi237ClokPhERERERkeZS0hqibhl6C+EmHICvDn/FzvydZ/Qc58DqKcJa1yoiIiIiIm1NSWuI6hHdg6sHXO09X5B9ZqOtKT7FmLSuVURERERE2pqS1hA2fXh1Qablu5ZzsuKk389w+hZjys3H5bItEpuIiIiIiEhzKGkNYRf1voiBXQYCUFRRxOqc1X4/Y1CPWBJiIwEoKK1g55HiFo1RRERERESkMUpaQ5jDOEgb6lOQ6QymCBtjaoy2btAUYRERERERaUNKWkPczUNuJsIRAcDWo1v59ti3fj+j5rpWFWMSEREREZG2o6Q1xHXr1I3rkq7znp/JaKvTJ2nVSKuIiIiIiLQlJa0dwLRh07zH7+9+n5KKEr/6j+zThU4R7l+VvfmlHCgobdH4REREREREGqKktQMYe85YBncdDMDJypOs3L3Sr/4RYQ4u7O9TRVhThEVEREREpI0oae0AjDFMG1492jo/az7W+rd1TYrv1jeaIiwiIiIiIm1ESWsHcdPgm+gU1gmArPwsth7d6lf/mutaNdIqIiIiIiJtQ0lrB9ElsguTBk3yns/Pmu9X/wsHxOMw7uMdBwspPFXRkuGJiIiIiIjUS0lrBzJ92HTv8aqcVRSUFTS7b1ynCM5L7AKAy8KmvBMtHp+IiIiIiEhtSlo7kFE9RjGi+wgAyqrKWLF7hV/9a+7XqnWtIiIiIiLS+pS0diDGmBrb3/hbkMnpU4xJ+7WKiIiIiEhbUNLawUw5dwox4TEA7C7YzVeHv2p2X+fA6pHWzXtOUF7pavH4REREREREfClp7WBiI2KZcu4U77k/BZl6d+1E/+7RAJyqcPHN/uaviRURERERETkTSlo7IN8pwh/mfkj+qeZvYZMy0Hddq7a+ERERERGR1qWktQM6L+E8LuhxAQAVrgqW7lza7L4192vVulYREREREWldSlo7KN/R1gXZC3DZ5q1PTfEpxpSZm+9XIScRERERERF/KWntoCYNmkRcRBwAeUV5fHHgi2b1G9yzM/ExEQAcLyln99ES941ThVBytFViFRERERGRjktJawcVHR7NTYNv8p4vyF7QrH4Oh8E5sHq0NXfjGnjzh/DEufD50y0ep4iIiIiIdGxKWjsw3ynCn+R9wpGTR5rVz3dd6+79h2FnOrgqYMcK0HRhERERERFpQUpaO7Ah3YYw9pyxAFTaShbvXNysfr7rWucfHQSRnd0nx3fDkawWj1NERERERDouJa0d3LTh1aOt72W/R5Wrqsk+o/p2JTLc/auTfbySU0k/qL65Y0WLxygiIiIiIh2XktYO7tqB1xIfFQ/A/pL9fL7/8yb7RIWHkdwv3nu+o+sV1Td3rGzxGEVEREREpONS0trBRYVFkTok1Xu+IKt5BZmcPlOEV5ePAUe4+2T/V1Cwr0VjFBERERGRjktJq5A2LM17/Pd9f+dgycEm+6T4FGNau68CknxGW7Peb9H4RERERESk41LSKgzsMpCLEy8GwGVdvPfde032GTugG8a4j7ftL6R86A3VNzVFWEREREREWoiSVgFg+rDp3uNF2YuodFU22r5rTATDe8UBUOWybIm9rPpmzj+g9ESrxCkiIiIiIh2LklYB4OoBV5PQKQGAw6WH+XTvp0328V3X+vnhKOg7zn3iqoTv1rRKnCIiIiIi0rEoaRUAIhwR3Dr0Vu95cwoy+a5rzcw9DiOmVN/U1jciIiIiItIClLSK1w+H/RCDe6Hq5/s/Z0/RnkbbO32S1q9y86kcOrn65nfpUHGqVeIUEREREZGOQ0mrePXt3JfL+lavTX0vu/GCTH3jo+nTtRMAJeVV7KhMhIQh7psVJfB901OMRUREREREGqOkVWrwLci0eOdiKqoqGm3vO9q6ITdfU4RFRERERKRFKWmVGq7odwXnxJwDwPFTx/loz0eNtk/xKcaUmZMPI26svpn1AbiqWiVOERERERHpGJS0Sg3hjnDShqZ5z5sqyFRjpDXnOLbvOIh1J72UHIG9G1olThERERER6RiUtEodtw69lTATBsCXB7/k+4LvG2w7rFcccZ3CAThcVMae/DIY4VOQSVOERURERETkLARt0mqMSTPGPGOM+YcxptAYY40xbzbQNslzv6Gfdxp5nzuMMV8aY4qNMQXGmAxjzI0Nte8IesX24sp+V3rPF2YvbLBtmMMwdkD1FOENOcdhxE3VDbavAGtbJU4REREREQl9QZu0Ag8Bc4BkYF8z+3wN/Ec9P/VmXcaYJ4HXgETgZeBN4AJguTFmzlnE3u5NH15dkGnprqWcqmx4+5oa61pzj8OgKyAyzn0h/3s4vL3V4hQRERERkdAWHugAGnE/sBfYCVwFfNKMPputtY805+HGmEuBXwG7gBRrbb7n+n8DG4EnjTErrLU5/ofe/l3a51L6du7LvuJ9FJQV8GHuh9w0+KZ629Zc15oP4VEw9Fr4ZpH74o6V0Ov8tghbRERERERCTNCOtFprP7HWfmdtq80t/RfP62OnE1bP++YAzwJRwF2t9N5Bz2EcpA3zKciU3XBBpjH94okIMwDsPFzM8ZJybX0jIiIiIiItImiT1jPUxxgz2xjzO8/r6Eba/sDzuqqeex/UatMhpQ5JJdy4B+M3Hd5Edn52ve2iI8MY1ber93xjbr57pNUR4b5wYDMU7G31eEVEREREJPSEWtJ6LfAC8Jjn9WtjzCfGmAG+jYwxsUBfoNhae6Ce53zneR3WmsEGux7RPbhm4DXe88a2v0nxmSKcmXMcOnWFQdXFnNjxfqvEKCIiIiIioS2Y17T64yTwe2AJsNtzbTTwCHA18JExJtlaW+K5d3pYsKCB552+Ht/QGxpjZgGzAHr16kVGRsaZxh7UhpYOZTWrAViSvQTnSSdRjqg67ToVVXqPP9qSw/iYQ/RxDGUYHwGQv24eX5d26O8ApAMoLi4O2b8LRESkJv2dLx1VIH73QyJptdYeBv5frct/N8ZcB3wGXAzMBJ7299GNvOdLwEsATqfTTpgwwc9Htw9X2atYsWQFOYU5nLKnKOlfwvVDr6/T7oLiMv6yKR2A3CLLJZddQafS4fDUCwB0K/iGCRePgehudfqKhIqMjAxC9e8CERGpSX/nS0cViN/9UJseXIO1thJ4xXPqM1fVO5Lalfo1NRLbYRhjahRkmp81v952CZ2jGNwzFoCKKsvXe05Al0To63Q3sFWQvabV4xURERERkdAS0kmrxxHPa+zpC55pwvuAzsaYxHr6DPW81l95qIO5efDNRDoiAfjm2Dd8c+ybetvVWNea6ynIrCrCIiIiIiJyFjpC0nqJ53V3resfe14n1dPnhlptOrT4TvFcl3Sd97yhgkw192s97j44z2dv153pUFHaKjGKiIiIiEhoComk1RhzsTEmsp7rPwDu95y+Wev2C57XB40x3Xz6JAH3AmXAqy0ebDs1ffh07/H7379PcXlxnTYpSdXrVTfm5lPlstBjKPTwFGCqOAm7M1o7VBERERERCSFBm7QaY1KNMa8ZY14DfuO5PP70NWPMkz7N/wvYZ4xZYIz5k+fnI+AjIAp42Fq71vf5nvOngMHAFk+fZ4FMoDvwgLU2p1U/ZDuS3DOZIfFDACitLGXl7pV12gzoHkPPOHdl4aJTlWQfKnLf0BRhERERERE5Q0GbtALJwB2en9Plas/1uZbm03Ye8AWQAvwU+DnudanzgSuttY/W9wbW2l8BdwIHcW9fMwP4BrjJWvvXlv047ZsxhmnDpnnP381+F2ttnTa+o62Zp6cIj7ixulHWB+CqatVYRUREREQkdARt0mqtfcRaaxr5SfJpO9dae6O1Nsla29laG2WtHWCt/ZG19h9NvM/r1toUa22stTbOWnuVtVbDgfW4cfCNdArrBMB3+d/x9ZGv67RxDvRd1+opxtRnLHTu7T4+eQz2fNHqsYqIiIiISGgI2qRVgk+XyC7cMOgG7/mC7LoFmWpUED490upwwIjJ1Y121J1aLCIiIiIiUh8lreIX34JMq3NWU1BWcyvb8xLjiIkMA2B/wSn2nfBUC669rrXW1GIREREREZH6KGkVv4xMGMl53c8DoKyqjGW7ltW4Hx7mYOyAeta1Jl0JUV3cx/k5cPjbtghXRERERETaufBAByDtizGGacOn8Z/r/hNwTxG+/bzbMcZ42ziTuvHZzqOAe7/Wm5P7QngkDL0Wtr3nbrRjJfQa2ebxi4iISMdUVVVFYWEhRUVFlJaW4nK5zup5Xbt2Zfv27S0UnUjbczgcREdHExcXR5cuXQgLCwt0SA1S0ip+mzxoMv+T+T+UVJTwfcH3ZB7KJKV3ivd+zXWt+dUdR0zxSVpXwFX/t61CFhERkQ6svLyc3NxcYmJiiI+Pp2/fvjgcjhpfuvurqKiIuLi4FoxSpO1Ya3G5XJSUlFBUVMTRo0cZOHAgkZGRgQ6tXpoeLH6LjYhlyqDqNaq1CzIl948nzOH+P4GsQ0UUnKxw3xhyLYR5/iAc+BpO5LVJvCIiItJxVVVVkZubS48ePejbt693ROlsElaR9s4YQ1hYGF26dKFv37706NGD3NxcqqqCc2tKJa1yRnwLMn2Y+yHHSo95z2OjwhnZx71+1Vr4Ks8z2tqpCwy6qvohO95vk1hFRESk4yosLCQmJoZu3bo13Vikg+rWrRsxMTEUFhYGOpR6KWmVMzK8+3BG9xwNQKWrkqW7lta4X3O/1uPVN2pXERYRERFpRZrGK9I8cXFxFBUVBTqMeilplTM2bdg07/HC7IW4bHVBg5Qk3wrCPutah08GPNNxctfCSZ+EVkRERKSFlZaWEhsbG+gwRIJebGwspaWlgQ6jXkpa5Yxdn3Q9cZHuby73FO1h/YH13nvjfJLWzXtPUFbpmR8f1wv6eYo22SrIXt1m8YqIiEjH43K5cDj0T16RpjgcjrOuqt1a9CdYzlh0eDQ3D77Ze74gq7og0zlxnUhKiAGgvNLFtn0F1R01RVhERETakIouiTQtmP+cKGmVs+I7RfiTPZ9w+ORh77kzyXddq+/WNzdWH+/8CMpPtmqMIiIiIiLSfilplbNybvy5jOs1DoAqW8Xi7xZ779Vc1+qzdrXHEOgx3H1cWQq7M9oiVBERERERaYeUtMpZmz6sevubhd8tpMrlXr/qO9KamZuPy2WrO9WYIryy1WMUEREREZH2qcWTVmNMtDGma0s/V4LXxIET6RblHlU9WHKQz/d/DsC5PWLpHhsJwImTFew6Ulzd6TyfKcJZ70NVZZvFKyIiIiIi7YdfSasxpr8xZpYxZmo99y4wxnwBFAHHjTHrjDEjWypQCV6RYZGkDkn1ns/Pmg+4F3M7B1ZPEa6xrjXxQojr4z4uPQ57qisPi4iIiIiInObvSOtM4HlgnO9Fz8hqOuD0PNMAFwMfGWN6tECcEuTShqV5j/+x7x8cKD4AQIrvFGHfda0OB4yYXH2uKcIiIiIiIlIPf5PWiZ7Xd2td/ynQE8gDJgFXAVs91355NgFK+zCgywAuSbwEAJd18d537wHg9CnGtCH3eM1Otbe+sRYRERERCU3GGL9/kpOTG33m+vXrmTNnDuPGjSMhIYGIiAhiY2Pp378/EyZM4L777uPtt9/myJEjzYqrJZSXl5OZmcmLL77IT3/6U8aOHUtkZKT3Pd58802/n2mt5e2332bKlCn069ePqKgoEhMTmThxInPnzqWyMrSX2oX72b4/YIHval2/xXP936y1awCMMT8F1gNTgIfOMk5pB6YPn876A+5pvou+W8TsMbMZ2acrnSIcnKpwsed4KQcLTtG7ayd3h4GXQ1RXKCuAE3lwaBv0viCAn0BERERE2oOCggJmzpzJwoUL69yrrKzk5MmT7N27l08//ZS//OUvGGMoKioiNja21WNLSUlhy5YtLfa8Y8eOkZaWRkZGRo3rBw8e5ODBg3z00Ue8+OKLLFq0iH79+rXY+wYTf5PWnsAJa23F6QvGmE5AClABLD993Vr7pTGmAhjcEoFK8JvQfwI9ontwtPQoR0qP8OmeT5k4cCLJ/eNZv9s9ypqZe5wbR3vWsoZHwrDrYOsC9/mOlUpaRURERDqAxYsXN90I6Nq1bn3XiooKrr/+er744gsAIiIimDp1KpdffjmJiYlYazl48CCbNm0iPT2d/fv3Y63FttGsvqqqqhrniYmJREREkJeX5/ezysrKmDp1KmvXrgVgwIABzJo1i8GDB7Nnzx7mzp1LVlYWGzZsYPLkyXz++efExcW1yOcIJv4mrVVAl1rXLvE8Z521trTWvSKg9b/OkKAQ4YjgliG38PLWlwFYkL2AiQMnkpLUvTppzcmvTlrBPUXYm7SugAm/aeuwRURERKSNpaamNt2oAc8++6w3YU1KSuKDDz5gxIgR9ba11rJ27VpeeOEFHI622e1z4sSJpKWlMW7cOJxOJ4mJiTz00EM89thjfj/rr3/9qzdhdTqdfPjhh8THx3vvz5kzh6lTp5Kens7WrVv5wx/+wOOPP95inyVY+Ptf7nsgzBhzqc+1NNxTg//u29AYEwF0BQ6dVYTSrqQNS8PgXg+wdv9a9hTuqbFf64acWutah0yEMPe2OBzcCvm5bRWqiIiIiLRDb731lvf4+eefbzBhBfd61csuu4x58+YRExPTFuHx5z//mUceeYSbbrqJxMTEM35OeXm5NwF1OBzMmzevRsIKEB0dzbx584iOjgbg6aefJj8/v86z2jt/k9ZVuCsDv2qMmWaM+QXuisIAtcf4xwBhuIszSQfRp3MfLu97ufd8wXcLGDsgHodnXfv2A4UUl/ksFI+Kg3MnVJ9nvd8mcYqIiIhI+7Rjxw7v8VVXXRXASFpXeno6x44dA+C6665rMDnv3bs306dPB6C0tJTly5fX26498zdpfQI4CAwF3gH+BEQCy6y1X9Zqe7o409+RDmX68One46U7lxIVYRnR2z2r3GVhU16tb398qwhvX9EWIYqIiIhIO+W7ZrSxqsDt3Zo1a7zHkyZNarSt7/2931mPAAAgAElEQVRVq1a1WkyB4lfSaq09gnsN62vADuBL4N+BH/m280wNngYUAqtbIlBpP67oewW9Y3sDcPzUcT7K+4gU361vcmolrcMng2dKMXlroeRYG0UqIiIiIu3N4MHVdV6feeaZAEbSurZt2+Y9HjduXKNtnU5nvf1Chd+rka21edbau621I6214621v7fWltdqU2GtHWat7Wat/UfLhSvtQZgjjFuH3uo9n581v8a61sza61o7nwP9L3YfWxdkh963QyIiIiLSMm677Tbv8ZNPPklqaiorVqygqKgogFG1vOzsbO9xUlJSo2379+/v3WfWt1+o8Ld6sEiz3DrkVl78+kWqbBWZhzL5l1EF3nub8k5QUeUiIsznO5MRU2CPe49XdqyEC/+5jSMWERGRji7pNysDHULA5PxxStONWtDpBKspr776KnfeeWeNa/fffz/Lli3zVhBeunQpS5cuxeFwMHz4cJxOJ5dccgkTJkzg/PPPb+nQ28yJEye8xz169Gi0bVRUFJ07d6aoqIiysjJOnTpFp06dWjvENtOidZ+NMTcYY/5ojPmTMabxidcS0nrF9mJC/wne84z9y+jXzV3VrLSiim/3F9bs4LuuddfHUH6yDaIUERERkfYmOjqajz/+mPvvv79GYuZyudi+fTvz5s3j3nvvZeTIkYwZM4YFCxYEMNozV1JS4j2Oiopqsv3pCsJAyI06+zXSaoyZDvwZWGmt/Wmtey8Avtd+YYx50Vr787MPU9qjacOm8VHeRwAs27WMcQOvZm++eyvfDTnHGdPfp2R3wmDoeR4c2Q6Vpe7E9bwbAxG2iIiIiLSyxYtrbzxSv7Fjx9Z7PSYmhqeeeooHH3yQhQsXkp6ezrp169i3b1+Ndlu2bGH69OnMmDGDV199tc32am1JzR2VDmX+Tg9OBXoBNfYlMcZcCczynK4HSoEJwGxjzEprbceda9GBje8znr6d+7KveB+F5YXEJG7D/esDX35/nJlXnFuzw4gp7qQV3FOElbSKiIhIG/JnimxRURFxcXGtGE1oS01NbZHnJCQkMHv2bGbPng3AwYMHWb9+PWvWrOGtt96isNA9u++NN95gyJAhPPzww349f/v27WRlZTV43+l00q9fvzP/AI2IjY2lqKgIay1lZWVNTvctLS31Hofa76a/XzWc/qqjdnGluz2vL1lrL7XWXgM8jLsk7D1nEZ+0Yw7jYNqwad7znaUfeo/Ttx8i/dtDNTv4ThHO/gCqKhERERERaa7evXuTmprKc889x+7du7n88su995544okaiV1zvPXWW9xyyy0N/mRkZLTwJ6gWH189K/H0fq0NKS8vp7i4GHBPJQ6l9azgf9LaEzhlrT1a6/p1uPdk/bPPtWc9rxedYWwSAlKHpBLucA/oZ53Yxuhz3WtVXRb+z9ub2Lq3ukATfS6EuD7u49J8yFvX1uGKiIiISIhISEjg7bffJjzc/W/R4uJivvzyywBH1XzDhg3zHufk5DTaNi8vD2ttnX6hwt+kNQ6o8L1gjEkCegP7rbU7Tl+31hYAJ3AnutJBJUQnMHHARO/56PO20797dUGmu1/fwN58T9ElY2qOtu5Y0ZahioiIiEiI6devX40kbv/+/X71f/TRR7HWNvhz++23t3TIXqNGjfIeZ2ZmNtrW975vv1Dhb9J6HIgzxnT3uXat5/WzetpHAMVnEpiEjunDp3uP0/e8z3O3j6JLJ/c3XkeKyrj7tQ0UnvJ8F1IjaV0Jnm+MRERERETORGRkpPe4c+fOAYzEP9dff733ePXq1Y22XbVqlfd40qTQ28TF36T1K8/r/QDGmGjgXtxTg9N9GxpjegOxwIGzjFHaOWcvJ0ldkgAoqSghu/gfvDTDSUSYZwPkQ8X8/M2vqKhyQdLl0Kmru2PBHji4JUBRi4iIiEgwOnToUNONPHJycti6dav3vD3t23rNNdeQkJAAuJPWHTt21Nvu4MGDzJ8/H3BvezN16tQ2i7Gt+Ju0voi7uNLvjDHfAN8Bo3FPA55fq+3VnldlHR2cMaZGQab52fO55NwEnkgb7b322c6jPLR4G9YRDsN8vh3aocLTIiIiIlItJSWFmTNnNjlldu/evaSlpVFVVQXA+PHjGTx4cFuE2CIiIyP57W9/C7j3oJ0xYwYnTpyo0aa0tJQZM2Z4C0zdd999NQo4hQq/tryx1i41xjwO/BtwnufyceAn1traO9je4XlNRzq8m4fczNNfPU25q5xvj33LN0e/4ZYLR5J77CR/Tv8OgHcz9zAgIYZ7R0yBLe+6O+5YCVf/LoCRi4iIiEhLW7JkSbPbTpkyhYiICO95eXk5c+fOZe7cuQwZMoQrr7yS5ORkevbsicPh4NChQ6xbt44lS5Z4k7nOnTvz3HPPtfjnqM/GjRvr7EP76aefeo8XLlxYZ9R01qxZDBgwoM6z5syZw6JFi1i7di0bNmwgOTmZWbNmMXjwYPbs2cMrr7zi3ZLnggsu4He/C81/N/u7TyvW2geNMS/hrgpcCHxhra2R8htjInDv5foBsKwlApX2rWtUV65Pup7lu5cDsCB7ASN7jOS+a4aSd/wki75ybwT936uzGJh2HjeGRUFVGRzaBse/h+6DAhm+iIiIiLSgW265pdlt8/Pza4wejh49mvT0dKy17Ny5k507dzbaf+TIkbz22mskJyfXuWd96qc4HP5OQq3fpk2beOyxxxq8v3TpUpYuXVrj2qRJk+pNWqOioli2bBlpaWlkZGSQm5vLgw8+WKed0+lk8eLFIbc/62ln9F/GWptrrV1grV1dO2H13K+w1v7FWvt0PdvjSAflW5Dp/e/fp6i8CGMMf7x1NOPPTfDe+9fFuziReFl1x6z32zJMEREREQlia9asIS8vj7lz53LXXXeRkpJCz549iYyMJCIigu7du3PhhRdyzz33sGzZMjZv3ozT6az3WadOnfIeB2uRpoSEBD7++GP+9re/ccMNN9CnTx8iIyPp1asX11xzDa+88grr1q2jX79+gQ611fg90ipypsb0HMOQ+CHsPLGT0spSVuxewW0jbiMy3MELt4/j1uc/Z9eREsqrXPx53zAe4WN3xx0rYfy9gQ1eRERERM6KbcFdIfr168fdd9/N3XfffVbPOXCgumbsOeecc7ZhATBz5kxmzpzZIs86zRjDbbfdxm233daiz20vzngM3BgzwRjznDFmvTFml+dnvefahBaMUUKEMabGaOuC7AXev7y6xkTw2l0X0aOzuyT58tIxuHBXFyZvHZRowF5EREREWtaGDRu8x6G4v2mo8DtpNcb0MMasBj4CZuNe2zrI83OR59pHxphVxpgeLRmstH83nnsj0eHRAHyX/x1fH/nae69/9xhenuEkKtzBMbqS6fJsBG1dkPVBIMIVERERkRBVXl7OU0895T2fMmVKAKORxviVtBpjIoEPgYm4t75ZDzwG/Mzz85jnmgGuBdZ4+ogAEBcZxw2DbvCez8+quVPShQO68fSPkzEG1lRVrz2wO1a0WYwiIiIiEpp27NjBokWLePrpp7n44ov58ssvAfd04x//+McBjk4a4u9I6xxgDJAPXG+tvcxa+7C19kXPz8PW2suASbj3bh0DaDGi1DB9WPUU4dU5qykoK6hxf9KoRB6cfB5rXNVJa9V3H0NZcZvFKCIiIiKh55133uGHP/whv/zlL9m8eTMA8fHxvPvuu0FbiEn8T1p/BFhglrX2w4YaWWvXALNwj7jqKwupYWSPkZyfcD4A5a5ylu5cWqfNPZcP4qqLL2K7qz8A4bacz1bPr9NORERERMQfxhi6dOlCcnIyv/nNb9i+fTuXXnppoMOSRvibtA4HTgGLm2roaXMKGOFvUBL6pg2b5j32Lch0mjGGf7/pfLK7Xem9dmTDIv6efaTNYhQRERGR0PLII4/gcrkoKChg06ZNPP744/Tu3TvQYUkT/E1aI4AK24x61dZaF1CBttWRekweNJnYiFgAcgpzyDyUWadNeJiD6269x3t+teMrfvHWl+w4WNhmcYqIiIiISGD5m7TmAXHGmLFNNTTGjAPiPH1EaoiJiOHGc2/0ntcuyHRa9ICxVMX1BSDelHBexTfc/eoGDhWeqre9iIiIiIiEFn+T1vdxr1Oda4zp2VAjY0wvYC7u9a8rzzw8CWW+U4TT89I5VnqsbiNjCDuvOrm9zpHJ/oJT3PP6BkrKKtsiTBERERERCSB/k9b/Ao4Do4Edxpg/GmMmGWMuMMY4jTE/NMb8FdjlaZMPPNGyIUuoGN59OGN6jgGg0lXJkp1L6m84onrPrOvDMgHLtn2F3PfOJqpcTc5UFxERERGRdsyvpNVaexiYDBwCugG/xj2Suhn4ApiPe7/WGOAAcIOnj0i9pg+v3v5mYfZCXNZVt9HAS6FTPAB9zDFGme8BSN9+mP9c/k2dIk4iIiIiIhI6/B1pxVr7JXA+8O/AVtxTgI3nx3qu/T9gpLV2Q8uFKqHouoHX0SWyCwB7i/eyfv/6uo3CImDYJO/pbwft8h6/vi6X//08p7XDFBERERGRAPE7aQWw1p6w1v7eWpsMRAOJnp9oa22ytfZRa+2JlgxUQlOn8E5MHTzVez4/u4G9WH2mCF9a+QVTRid6zx9d+S2rvznYajGKiIiIiEjgnFHS6staW2GtPeT5qWiJoKRj8S3IlLEng8Mn65lRPuQaCO8EgDn8LU9dE8fYAe4pw9bCfe9s4us9+p5ERERERCTUnHXSKnK2zo0/F2cvJwBVtopF3y2q2ygyFgb/wHsatWsVL89wMqB7DACnKlzc83ome46fbJOYRURERESkbTSYtBpjrmypn7b8QNI+1S7IVOmqZzsbnynC7FhJQucoXrsrhfiYCACOFpdx12sbKCjVgL+IiIiISKgIb+ReBu7CSmfLNvE+Ilwz4Bq6RXUjvyyfQycP8dm+z5jQf0LNRsMmgXGAdUHeeig+wrk9e/LST5zc/soXlFe52Hm4mJ+9uZHX7rqIyHBNJBARERERae8a+1d9Xgv97Gml2CWERIZFkjo01Xu+IHtB3UaxPWDAeM+JhewPALhoUHf+e9pob7O1u47xu8VbtRWOiIiIiEgIaDBptdYmWWsHtcRPW34gab+mDa0uyPSPvf9gf/H+uo1qTRE+7ebkvvzq2mHe84Ub9/LXj3e2SpwiIiIiItJ2NH9Sgkb/Lv0Zn+geSbVYFmYvrNto+OTq412fQFmR93TOD4YwbVw/7/n/fJjNkk37Wi1eERERERFpfUpaJaj4FmRavHMxFa5aRZW6D4Jeo9zHVWWw8yPvLWMMf7j1Ai4bkuC99n8XbuGL3cdaNWYREREREWk9SlolqFzV/yp6RvcE4GjpUTL2ZNRt1MAUYYCIMAfP/fM4hp7TGYDyKhez5m1k15Hi1gpZRERERJrBGOP3T3JycqPPXL9+PXPmzGHcuHEkJCQQERFBbGws/fv3Z8KECdx33328/fbbHDlypFlxtYRDhw7x+uuvc9ddd5GcnEx8fDwREREkJCRw0UUX8etf/5qsrCy/nmmt5e2332bKlCn069ePqKgoEhMTmThxInPnzqWysp6dN0KIUbGas+d0Om1mZmagwwgZz2x6hpe2vATAJYmX8PJ1L9dscGALvHiF+ziqK/zfXRAWUaPJ3vyTpD67lqPFZQAM6B7D4p9fSkLnqFaPXzqujIwMJkyYEOgwRETEx/bt2znvvPNa/LlFRUXExcW1+HND2ZkkhWPGjGHz5s11rhcUFDBz5kwWLqxnOVkD711UVERsbGyjcZ1tbvTzn/+cl156iaqqqkbbORwOHnjgAR5//HEcjsbHEY8dO0ZaWhoZGRkNtklJSWHRokX069evwTbN0Zw/Lw39e8cYs9Fa6zyrABqgrWgk6KQNTeOVra/gsi7WH1hPXmEeA7oMqG7Q+wLoOgAK8qCsAHI+g8FX13hGv24x/O+dTn704npKK6rIO36Sn76Ryd9+egmdIsLa+BOJiIiIiK/Fixc3q13Xrl3rXKuoqOD666/niy++ACAiIoKpU6dy+eWXk5iYiLWWgwcPsmnTJtLT09m/fz/W2jbZWeLbb7/1JqyjRo3iBz/4AaNGjSI+Pp5Dhw6xcuVKVq1ahcvl4oknnqCwsJDnn3++weeVlZUxdepU1q5dC8CAAQOYNWsWgwcPZs+ePcydO5esrCw2bNjA5MmT+fzzz0PyyxQlrRJ0EjsnckXfK/h076cALMxeyL86/7W6gTHuKcJfeP6A71hZJ2kFGN0vnqd/nMzsNzdiLXyVd4Jfzf+aZ267EIejZaZ/iIiIiIj/UlNTm27UgGeffdabsCYlJfHBBx8wYsSIettaa1m7di0vvPBCkyOaLSE8PJyf/OQn/PKXv2Ts2LF17s+ZM4d33nmH22+/naqqKl544QVuu+02rrzyynqf99e//tWbsDqdTj788EPi4+NrPG/q1Kmkp6ezdetW/vCHP/D444+3zocLIK1plaA0bVj19jdLdi6hvKq8ZoPa61ob+ObsupG9eXjK+d7zlVsP8F+rd7RorCIiIiLSdt566y3v8fPPP99gwgruqb+XXXYZ8+bNIyYmptVjW7BgAW+88Ua9CetpP/7xj5kzZ473/PXXX6+3XXl5uTcBdTgczJs3r0bCChAdHc28efOIjo4G4OmnnyY/P/9sP0bQUdIqQenyvpfTO7Y3APll+aTnptdsMGA8RHdzHxfth/2bGnzW3ZcP4s5Lk7znL366m799kdfSIYuIiIhIG9ixo3oA4qqrrgpgJHV169atWe2mTaseoNm6dWu9bdLT0zl2zL0LxnXXXddgct67d2+mT3fvwFFaWsry5cv9Cbld8CtpNcaM9vx0bq2ARADCHGGkDU3zns/Pnl+rQTgMu6H6vFYV4doevvF8Jp53TvX50m1kZB1ukVhFREREpO34FjlqrCpwMPNdd1paWlpvmzVr1niPJ02a1OjzfO+vWrXqLKMLPv6OtG4GvgI6tUIsIjXcMvQWwoy7aNLGQxvZdWJXzQY1pgivaPRZYQ7DX267kAv6uhfzV7ksc/62iW/3F7ZozCIiIiLSugYPHuw9fuaZZwIYyZnbtm2b93jgwIFNthk3blyjz3M6q4v2+vYLFf4mrQVAgbX2aGsEI+LrnJhzuLp/dYGlhdm1SpoP/gGEu+fvc2QHHN3Z6PNiIsOZe4eTvvHuPsVlldz92gYOFpxq0bhFREREpPXcdttt3uMnn3yS1NRUVqxYQVFRUQCj8s/LL1dv6ThlypR622RnZ3uPk5KSGn1e//79vVv3+PYLFf5WD84GLjTGdLLW6l/60uqmDZ9Gep57PevSXUu5b+x9dAr3DPRHxrgT1yzP1OCsldDjvkafd06XTvzvnSmkPb+WorJKDhae4u7XNjD/X8bTOUrFtEVERDq0R+pur9KQkNtU5JGCNn275u7Z+uqrr3LnnXfWuHb//fezbNkybwXhpUuXsnTpUhwOB8OHD8fpdHLJJZcwYcIEzj///HqeGlhvvvmmd8/VxMRE7rjjjnrbnThxwnvco0ePRp8ZFRVF586dKSoqoqysjFOnTtGpU+hMjvV3pHUe7kR3RivEIlLHJYmX0K+ze5PkovIiVuesrtmgdhXhZhjeO47nbh9LuGfbm28PFPJ//vYVlVWuFolZRERERFpPdHQ0H3/8Mffff3+NxMzlcrF9+3bmzZvHvffey8iRIxkzZgwLFiwIYLQ1bdu2jZ/97Gfe82effbbBqsYlJSXe46ioqCaffbqCMNCuRp2bw9+hpWeBa4A/G2OqgFettfqXvrQah3Ewbfg0/rTxT4C7INPNQ26ubjD8BjAOsC7Y8yUUHYK4Xk0+94qhPXnsllH823vuam2fZB3hkeXf8PubRzX7mz8REREROTOLFy9uVruGto6JiYnhqaee4sEHH2ThwoWkp6ezbt069u3bV6Pdli1bmD59OjNmzODVV19tk71aG3LgwAFuuukmiouLAfjFL37BLbfc0mQ//dvU/6R1LnACqAReAh43xmQCR4CqBvpYa+09Zx6idHQ3D76ZZzY9Q6Wrki1HtpB1PIvh3Ye7b8Z0h4GXQc4/AAvZH8C4O5v13B+lDCDv+Eme/cRd4OnN9Xkkdo3m3quHtM4HERERkeDmxxTZoqKiGhVgxT+pqakt8pyEhARmz57N7NmzATh48CDr169nzZo1vPXWWxQWuotuvvHGGwwZMoSHH37Yr+dv376drKysBu87nU769evX5HOOHj3KxIkTycnJAeBHP/oRf/rTnxrtExsbS1FREdZaysrKmpzu61uFONR+N/1NWu8ELHA63e8BNF5/2d1eSaucsYToBK4dcC0f5HwAwILsBTx0yUPVDUZM8SStuKcINzNpBfjVtcPZc7yUZV/vB+C/V2fRPTaS2y4a0FLhi4iIiEgb6d27N6mpqaSmpvL73/+e1NRUPvvsMwCeeOIJHnjggRrTaJvy1ltv8dhjjzV4f968edx+++2NPiM/P59rr72Wb7/9FnAn7G+++WaTo77x8fHeab7Hjh2jb9++DbYtLy/3juBGRUWF1HpW8D9p/Y9WiUKkCdOGT/Mmrct3Lef+cfcTGxHrvjl8Mqz6jft4dwaUFUFU875dcjgM/z1tNMdKyvh8p3vz5gcXb6VbTCSTRvVu6Y8hIiIiIm0kISGBt99+m0GDBlFZWUlxcTFffvklV111VZvFUFBQwHXXXcfmzZsBd6Xgd999l/DwptOwYcOGsWfPHgBycnIaTVrz8vKw1nr7hRq/klZrrZJWCQhnLyeDug7i+4LvOVl5kve/f59pw6a5b3YbCL0vgINboaocdqbDyKbXB5wWFR7Giz9xcttL69m6rwCXhV+8s4nX77qI8YMTWukTiYiIiEhr69evH8OGDfOOcu7fv9+v/o8++iiPPvroGb13UVERkyZNIjMzE4Brr72W9957j8jIyGb1HzVqFB999BEAmZmZXHbZZQ22Pf0ep/uFmsCtRBbxgzGmOkkFFmQt8H6bBMCIG6uPt6/w+/mdo8J59a4UBvVwj96WV7r46RuZbNvXtuXfRURERKRl+SaJnTt3bpP3LCkpYfLkyaxfvx6Aq6++mqVLlzarCvBp119/vfd49erVjbSEVatWeY8nTWpq9Wb7c1ZJq3HrYYzRAkBpdVMHTyUqzP0Hffvx7Xxz7Jvqm75b33y3BirL/X5+j85RvHH3RZwT536P4rJK7nx1A7nHSproKSIiIiJt5dChQ81um5OTw9atW73nbbFva2lpKTfddJN3Le0VV1zB8uXL/VpLC3DNNdeQkOCe9bd69Wp27NhRb7uDBw8yf/58wL3tzdSpU88i+uB0RkmrMWa8MWYZUAgcAnbXuh9vjJlrjHnFGNP8rxNEGtE1qivXJ1V/4zQ/a371zV6jIN7z3UlZYXVhJj/17x7DG/dcRJdO7pnzR4vL+MncLzlcdOqM4xYRERGRlpOSksLMmTNrTImtz969e0lLS6Oqyr3Jyfjx4xk8eHCrxlZWVkZqaiqffPIJAJdeeinvv/8+sbGxfj8rMjKS3/72t4B7D9oZM2Zw4sSJGm1KS0uZMWOGt3LwfffdR3x8/Fl+iuDjbyEmjDH3An8GwhpqY609YYxJAG4CVgBL/HyPNOAqIBkYA8QBb1lrGyzNZYy5FHgIuAToBOwE/hd4xlpb73Y8xpgbgQeACz2f5xvgOWvt6/7EK21n2rBpLNu1DIBVOat4IOUBukR2AWPcU4TXP+duuGMlDLnmjN5jRO8uzL0zhdtf+YKyShd5x09yx/9u4N3Zl9ClU0RLfRQRERGRDmvJkuanB1OmTCEiovrfYOXl5cydO5e5c+cyZMgQrrzySpKTk+nZsycOh4NDhw6xbt06lixZ4k3mOnfuzHPPPdfin6O2n/zkJ6xZswaArl27Mnv2bNLT0xvt43A4GhwdnTNnDosWLWLt2rVs2LCB5ORkZs2axeDBg9mzZw+vvPKKd0ueCy64gN/97nct+4GChF9JqzHmIuBp3Pu0/hZ4G8gEzqmn+avAVOCH+Jm04k4+xwDFwF5gRBNx3Qy8B5wC3gWO406Y/wRcBkyrp88c4BngGPAmUA6kAa8ZYy6w1j7gZ8zSBsb0HMOwbsPIzs+mtLKUFbtW8E/n/ZP75ogp1Ulr1vsw+Uk4ww2kU5K68+w/jWX2mxupclm2Hyhk5uuZvHH3RXSKaPD7GhERERFphltuaX7RzPz8/Bqjh6NHjyY9PR1rLTt37mTnzp2N9h85ciSvvfYaycnJde751khpagua5li7dq33uKCggDvuuKPJPmFhYVRWVtZ7LyoqimXLlpGWlkZGRga5ubk8+OCDddo5nU4WL14ccvuznubvf5l/xb1H679ba5+01u5rpO2nnteLziCu+4FhQBfgZ401NMZ0AV4GqoAJ1tp7rLW/xj1Kuw5IM8b8uFafJOBJ3Mmt01p7r7X2fmA0sAv4lTFm/BnELa2sTkGmbJ+CTP0vgRhPtd+iA7B/01m918Tze/HHWy/wnn/5/XF+8fYmKqtcZ/VcERERETlza9asIS8vj7lz53LXXXeRkpJCz549iYyMJCIigu7du3PhhRdyzz33sGzZMjZv3ozT6az3WadOVS8Ba6siTf5KSEjg448/5m9/+xs33HADffr0ITIykv/P3n3HR1Xl/x9/nUnvJIEQILTQpUgJYgUURSSIDVDX3re439Xd7+7PVXfXsrt+3a9ft+q6u6IoVsBCV0TEBtJRkF5C6JAA6X3O7487TAIkJIGZTMr7+XjMY+6599x7PxEyzodz7ue0bduWUaNG8fLLL7N06VJSUlICHarf1Hd68CWe93/W1tEzRTgXqPd/PWvtZ8e3jTG1dZ8AtAFet9Z6J7Zba4uNMY8Dn+Ikvu9UOeduIAx41lqbUeWco8aYPwKTgR/iJL3SyIxLHcfzq56nqLyIbce2sfbwWgYlDYKgYColczIAACAASURBVOh5Fax9w+m4aQ6kDDmre01M68iRglKeme88+L5gw0Ee/3A9z1zfvy5/N0VERETE44SVH85SSkoKd999N3ffffdZXWf//v3e7aSk6iaP1s+ePXvO+hrVMcZw8803c/PNN/vl+o1dfUdaWwO51trcOva3Z3CP+rrM8/5RNce+AAqBC08qCHW6c+af1EcamejQaMZ2Hettn1CQqWoV4U1zfXK/B0Z04/7hqd72Oyt289yCzT65toiIiIgEzooVK7zbzXF90+aivgllDhBTl4rAxphkIA44fCaB1UMvz/uWkw9Ya8uBnTgjyql1PGc/UACkGGMifRuq+MrEXpVThBdkLOBYsaeSWrdLIcTzx5a1GbK2+uR+j4zpzQ2DKycNvPDZdiZ/tdMn1xYRERGRhldaWsrzzz/vbaenp5+mtwRSfacHf4szAjkSOP0Kt870WoBl9bxHfcV53nNqOH58f9Xaz3U5J8rTr7C6DsaY+4H7Adq2bcvixYvrGK74SqfQTmSWZlLqLuX5Bc9zWawzON43bgBtspyFnLfP+xu7O93gk/td1dqyrU0Q3x52ilE/PWcDBzO3c2H7ehfhlmYqPz9fnwUiIo1MXFwceXl5Pr9uRUWFX64r/rVlyxY2bdrEnj17eOutt/juu+8A6NChA+np6S3+z7S4uLjW7zKB+L5T32/brwOjgGeMMd9Ya6tN+owxtwKP4UwPfuXsQjxrxx88rM8k+lrPsdb+G/g3QFpamh05cuQZBSdn7sjWI/xuye8AWF2xmidHPOk8Z9pqP3zoJK3dSjfSzYd/NhddXMGtk5exatdRAF5ZX8qFQwYwstfZPwMhTd/ixYvRZ4GISOOyceNGv1RUzcvLa7aVWpuz2bNn8+STT56wr1WrVkybNo127doFKKrGIzw8nEGDBp22TyC+79R3evAbOIWNBgKrjDG/wVkTFWPMOGPMr4wxy4DXcNY9/dBaO7/Gq/nG8cQ5robjsSf1q885dX12VwJgTJcxRIc4Vd525e5i+YHlzoGeV4LxLEuzZwXkHfDZPSNCg3jljqH0auv8T6rcbfnRG6tZnXnUZ/cQEREREf8xxhAbG8vAgQN55JFH2LhxIxdeeGGgw5LTqFfSap2SX9cBM3GeEX2CygRvJvAMMBRnpPJ94DZfBXoaxyvi9Dz5gDEmGOiKs67sjjqe0w5navAea221U4OlcYgMiWRc6jhve/qW6Z4DCdC5ygfP5nk+vW9cZAiv3X0eHVpFAFBUVsHdU1aw7VDLnk4iIiIi0tg98cQTuN1ucnJyWLNmDc888wzJycmBDktqUe/KvtbafGvtdcAVwFs4hY6KgVJgN/AucJW1dkIDJX2LPO9jqjk2HIgEllhrS+p4zlUn9ZFGrGpBpk93fUpWUZbT6F2ZzPqqinBVyXHhvH7PeSREhQJwrLCM2yYvZ9+xIp/fS0RERESkJTvj5WistZ9aa2+z1na31kZZayOstV2stTdba2sr0uRLM4As4CZjjHfVYGNMOPB7T/PkdWVfBUqAB40xXaqcEw886mm+5Kd4xYd6xvdkYJuBAJTbcj7c9qFzoOrSNzs+h2Lfz/Tu1iaaKXcNJSrUmYq8P6eY2yYv42hBqc/vJSIiIiLSUvl7DdUzYoy51hgzxRgzBXjEs/uC4/uMMc8d7+tZM/Y+nGdoFxtjXjbG/AlYC1yAk9S+W/X61tqdwC+BBGClMeYFY8yfge+AbsD/WWuX+venFF+Z1GuSd3vGlhm4rRtadYR25zo73WWw7RO/3HtASiv+dVsaIUFO7a7thwu4a8oKCkrK/XI/EREREZGWpl5JqzHGbYzZW4/+O40xZ/LtfSBwh+d1pWdfapV9E6p2ttZ+CIwAvgBuAH4KlAE/B27yPIvLSef8HRgPfA/cjrN8zQHgTmvtf59BzBIgV3S+gthQ59Hqvfl7WbJviXPAz1OEj7u4R2v+fONAjKfm9Nrdx/jRm6spLXf77Z4iIiIiIi3FmYy0mtq7nFV/rLVPWGvNaV5dqjnna2vtWGttvGeqcn9r7Z+ttRWnuc9sa+0Ia22MZ4rzUGvta/WNVwIrPDica7pf421P3+wpyFR1ivCWBVBegr+MG9Cep8b39ba/2HKYX874Fre7PistiYiIiIjIyfw9PTgMqDFpFPGViT0rCzJ9vudzDhQcgKRzIL6Ls7M0D3Z+6dcYbrugCz8b1cPbnrl2H0/N2UA1A/0iIiIiIlJHfktajTHJQBJOkSQRv+oa15WhyUMBqLAVfLD1AzDmpCnCc/wex0OX9+CWYZ287SlLMnhx8Xa/31dEREREpLkKPt1BY8xwYORJu6ONMb893WlAK5zlZAzw9dkEKFJXk3pOYsWBFQC8t/U97htwH8G902HpP5wOm+dB+vPg8t8EA2MMT13Tj6OFpcxbdwCA//14MwlRodx8XqdazhYRERERkZOdNmkFLgV+B1Sd3xjl2Xc6x59jPQI8eWahidTPqE6jSAhP4EjxEQ4WHuTLPV9yacfhEJkIhdmQfxD2roKOQ/0aR5DL8OcbB3KscAVLtmcD8NgH64iPDGVMPy1eLSIiIiJSH7UNOa0FXgNe97wAiqu0q3tNAf6KU423l7V2vc+jFqlGSFAI13a/1tuetmUauIKg11WVnRpgijBAWHAQ/749jX4dnKrGbgv/9c4alnqSWBERERERqZvTJq3W2pnW2ruOvzy7c6ruq+Z1j7X2YWvty9ZafUOXBjWhZ+VqSF/v/Zq9+XsbbOmbk0WHBTPlrvPokhgJQGm5m/teX8n6vTkNFoOIiIiISFNX34f7LsVZB1WkUeoY05GL2l8EgMXy3pb3IHUkhEQ5HbK3wuEtDRZP6+gwpt4zjKSYMADyS8q589UV7MouaLAYRERERESasnolrdbaz621S/0VjIgvVF3+5v2t71MWFAzdR1V2aKApwsd1TIjk9XvOIzbceYQ8K7+E2yYv51BecYPGISIiIiLSFPl7nVaRBje843CSIpIAyC7O5rPMzwI2Rfi43smxTL5zKGHBzq9c5pFC7nhlBbnFZQ0ei4iIiIhIU1KvpNUYU3EGr3J/BS9SnRBXCNf3vN7bnrZlGvQcDSbI2bF3JeTua/C4hnZJ4IUfDCbI5RTX3rg/l3tfW0lxWUWDxyIiIiIi0lTUd6TVnMFLo7nS4G7ocQMu4/zVW7Z/GbvKcqHLxZUdNs8LSFyXn9OW/7m+v7e9fOcR/uvtNZRXuAMSj4iIiEhDMcbU+zVw4MDTXvObb77hwQcfZMiQISQmJhISEkJUVBQdO3Zk5MiR/OxnP+Ptt9/m8OHDdYrLF1JSUur8811++eV1uqa1lrfffpv09HRSUlIICwujXbt2XH755UyePJny8uY9TljbOq0n61rL8ThgKPAQ0A64C/juDOISOSvJUckM7zCcxXsWAzBjywx+0Xsc7Pzc6bBpLgy9NyCxTUzrSHZBKf8zfxMACzYc5PEP1/PM9f199mEpIiIi0pzl5ORw7733MmPGjFOOlZeXU1hYyJ49e/j888/529/+hjGGvLw8oqKiAhDt2cnOzmbChAksXrz4hP0HDhzgwIEDfPrpp/zrX//i/fffJyUlJTBB+lm9klZr7a46dPvOGDMVmA9MBoacSWAiZ2tir4nepPXDbR/y4OjXCJvvObjzCyg6BhGtAhLbA8NTyc4v4T9f7gTgnRW7SYgK5VdjegckHhEREZGG9MEHH9SpX1xc3Cn7ysrKuPLKK1m2bBkAISEhjB8/nosvvph27dphreXAgQOsWbOGhQsXsm/fPqy1WGt9+jPUJjk5mX/+85+n7ZOUlHTa4yUlJYwfP54lS5YA0KlTJ+6//366devG7t27mTx5Mps3b2bFihWMHTuWr7/+mpiYGJ/9DI1FfUda68RaW2qM+S9gHfA7IDBDWtKiXdT+ItpFtWN/wX6OlRzjk2MbGNduIOxfC+5y2LYQ+k+o/UJ+YIzh11f1IbuglPdX7wXgxcXbiYsI4YER3QISk4iIiEhDufbaa8/43BdeeMGbsHbp0oX58+fTu3f1//BvrWXJkiW89NJLuFwN+9RiVFTUWf2cAP/4xz+8CWtaWhqffPIJrVpVDro8+OCDjB8/noULF7Ju3Tr++Mc/8swzz5zVPRsjv/3JWWu/B3KBMf66h8jpBLmCmNCzMimdvnn6SVWEG3bpm5O5XIZnbxjAZb0r/4XtmfmbeHt5ZgCjEhEREWnc3nzzTe/2P//5zxoTVnAGCi666CKmTp1KZGRkQ4TnM6Wlpd4E1OVyMXXq1BMSVoCIiAimTp1KREQEAH/96185evRog8fqb35LWo0xoUAkkOive4jU5rru1xFsnAkFqw+tZluHAZUHt34C5SUBiswREuTixVsGc17XBO++Rz9Yx+xvG766sYiIiEhTsGnTJu/2iBEjAhiJfy1cuJDs7GwARo8eXWNynpyczKRJkwAoKipi9uzZDRZjQ/HnGPkPcKYf69u3BEybyDZc2ulSb3t69mpISHUapfnOs60BFh4SxOQ70ujfwXlmw1p4+N21fLb5UIAjExEREWl8Kioqlws8XVXgpm7BggXe7TFjTj95terxjz76yG8xBUp912ntVMurpzHmMmPMX4EXAQtM90vkInU0sedE7/bs7bMp6nVl5cEATxE+LiY8hNfuPo9ubZyKduVuy4/eWMXynUcCHJmIiIhI49KtW2X9j7///e8BjOT0Dh8+zKhRo2jTpg2hoaG0adOGYcOG8cgjj7Bjx45az1+/fr13e8iQ09e2TUtLq/a85qK+I607a3ltBD4BHgTCgeXA074KVuRMDGs3jI4xHQHIK8vjo1ZtKg9umgfuihrObFgJUaG8ce8wOrRynkkoLnNzz5QVrN+bE+DIRERERBqPm2++2bv93HPPce211zJnzhzy8vICGNWpcnNzWbRoEVlZWZSVlZGVlcXy5ct59tln6dmzJ48//jhut7vG87ds2eLd7tKly2nv1bFjR+/SiVXPay7qWz24tkUkK4BjOFWDpwEvW2ub90q30ui5jIuJPSfy/KrnAZh+eCXXRbWBgsNQcAj2rIROwwIcpaNdXARv3juMCS8tJSu/hLyScm5/ZTnTHriA7knRgQ5PRESkWev/Wv9AhxAw6+5Y16D3q+va9K+++ip33nnnCfsefvhhZs2a5a0gPHPmTGbOnInL5aJXr16kpaVx/vnnM3LkSM455xxfh14nHTp0YMyYMQwcOJCkpCRKS0vZunUr77//PuvXr6eiooI//OEP7N+/n8mTJ1d7jWPHjnm3W7dufdr7hYWFER0dTV5eHiUlJRQXFxMeHu7TnymQ6jXSaq111fIKsda2sdZeZq19SQmrNBbXdL+GEFcIAOuy17Ox28WVBxvJFOHjurSOYuo95xEb7vyb0pGCUm6bvIw9RwsDHJmIiIhI4EVERLBo0SIefvjhExIzt9vNxo0bmTp1Kj/5yU/o27cv5557LtOnN+zTim+//Ta7d+/m5Zdf5sEHH2TSpEnceuutPPnkk3z33Xf8/e9/9y6/88orr/Duu+9We52CggLvdlhYWK33PV5BGGh0o85nyy/rtIo0NgnhCVze+XLm75wPwPTIEH57/OCmOXDFU1DHf/FrCH3axTLl7vO49eVlFJZWsD+nmFtfXsb0H15Im5jaP7REREREGrMPPvigTv0GDx5c7f7IyEief/55HnvsMWbMmMHChQtZunQpe/fuPaHfd999x6RJk7j99tt59dVXG2St1ksuuaTGY8YYHnzwQY4cOcLvfvc7AH7/+99z4403nvacls5YawMdQ5OXlpZmV65cGegwpBYrD6zkro/vAiAyOJJFu3YTVer5F6wfL4Okmtf4CpSvtmZx95QVlFY4zzv0aRfLO/edT1xkSIAjk+osXryYkSNHBjoMERGpYuPGjfTp08fn183LyyMmJsbn123OqiZf/spBDhw4wDfffMOCBQt48803yc3N9R576qmn+M1vflOvuDZu3MjmzZtrvF9aWhopKSn1jrOoqIikpCTy8/MB2LVrF506dTqhT2xsrHfEtKioqNbpvvXtX526/L7U9H3HGLPKWpt26hlnr97/1GCMaW+MuckY86Qx5h+e11Oefe39EaSILwxpO4TUOGe5m8LyQuZ2GVh5sJFNET7u4h6t+dvNg3B5Pks37s/lrinLKSzVzHsRERGRkyUnJ3Pttdfy4osvsmPHDi6+uPKRsD/96U8UFRXV63pvvvkm1113XY2vxYsXn1GcERERDBtWWVOlusS4VatW3u3j67XWpLS01JsAh4WFNavnWaEeSasxZoAxZiaQCbwJPA78yPN6zLMv0xgz0xgzsOYriQSGMeaE5W+mB5fi/be0TXMDElNdjOmXzJ8mnOttr848xgNTV1FS3jiqHouIiIg0RomJibz99tsEBztPRObn57N8+fIAR1UpMTHRu3306NFTjvfs2dO7nZGRcdprZWZmekeJq57XXNQpaTXG3AcsA8Z5zjFAGXAIOOzZNp5j44BvjDEP+CNgkbNxdberCQtyngndVHSQ9eGeB9b3rYacvac5M7AmDEnht+Mqq999uTWLh95ZS3lFzWXSRURERFq6lJSUE5K4ffv21ev83//+91hra3zdeuutZxxb1dHTqqOqx/Xr18+7XdujiFWPVz2vuag1aTXG3Ay8BIQBB3BGVfsCEdbadtbaZCDCs+9xT59Q4EVjzA/8FbjImYgLi2NMlzHe9rR2qZUHN88LQER1d/fFXXno8h7e9vz1B/j1++twu/VcuoiIiEhNQkNDvdvR0Y1jCcGioqITRn2rGx298sorvdsff/zxaa/30UcfebfHjBlzmp5N02mTVmNMAvCCp/kB0Mda+4y1dqOt8pSydWy01v4R6A3MxBl5fcFzDZFGY2KvyinCH5kico8/MNpIn2ut6mejenD3RV297emr9vCHeRv9VsxAREREpLE5ePBgnftmZGSwbl3lGrSBWrf1ZM8995y3aFKfPn3o0qXLKX1GjRrlnUL88ccfs2nTpmqvdeDAAaZNmwY4z8qOHz/eP0EHUG0jrQ8ArYAVwERrbW4t/bHW5gETPOfEeq4h0mgMaD2AXvG9ACi25cyOjnIOZHwFRac+T9CYGGN4PL0PE4ZUVqmb/NVO/r5oWwCjEhEREWk4Q4cO5d577611yuyePXuYMGECFRVOHZALLriAbt26+TW2p59+usbk8rgXXniBJ554wtt+7LHHqu0XGhrKr3/9a8BZg/b222/n2LFjJ/QpKiri9ttv9xaY+tnPflbtVOOmrrZ1WscCFviNtbbOD89ZayuMMb8BPvJc45kzD1HEt4wxTOo1iae/eRqA6fFt+EFuPsZdDls/gQGTAhzh6blchv+5vj/5xeV89P0BAJ7/ZAsx4cHcVWUUVkRERKSx+vDDD+vcNz09nZCQyuX+SktLmTx5MpMnT6Z79+4MHz6cgQMH0qZNG1wuFwcPHmTp0qV8+OGH3mQuOjqaF1980ec/x8neffddfvvb3zJ48GBGjBhB7969iY+Pp7S0lK1bt/Lee++xfv16b/8777yTW265pcbrPfjgg7z//vssWbKEFStWMHDgQO6//366devG7t27efnll72Vh/v378+jjz7q958xEGpLWnsAbmDRGVz7U6DCcw2RRmVs17E8t/I5isqL2O6qYHVYGENKSpwpwo08aQUIDnLx15sHcu9rK/lyaxYAT87eQGx4CDcMqf9aYSIiIiIN6brrrqtz36NHj54wejhgwAAWLlyItZZt27axbdvpZ5z17duXKVOmMHDgqQucVH3EyuWq92qgNVq9ejWrV6+u8XhISAiPPvpotevGVhUWFsasWbOYMGECixcvZteuXdWOzKalpfHBBx8027WDa0ta44Eca22919bwjLbm4EwvFmlUokOjSU9NZ8aWGQBMj41myOES2LoQyooh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\n",
      "text/plain": [
       "<Figure size 1080x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "s1 = 9\n",
    "s2 = 15\n",
    "s3 = 30\n",
    "\n",
    "lw = 3\n",
    "iters = list(range(K))\n",
    "plt.plot(run_zoj10[2:s3], val_zoj10[2:s3], '-', label='ESJ-10', linewidth=lw)\n",
    "plt.plot(run_zoj20[1:s2], val_zoj20[1:s2], '-', label='ESJ-20', linewidth=lw)\n",
    "plt.plot(run_zoj50[:s1], val_zoj50[:s1], '-', label='ESJ-50', linewidth=lw)\n",
    "#plt.plot(run_fp[1:s2], val_fp[1:s2], '-', label='AID-FP', linewidth=lw)\n",
    "plt.xlabel('Running time', fontsize=24)\n",
    "plt.ylabel('Outer loss', fontsize=24)\n",
    "plt.xticks([0.1, 0.2, 0.25], fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.legend(loc='center right', fontsize=30)\n",
    "plt.grid()\n",
    "plt.gcf().set_size_inches(15, 8)\n",
    "plt.savefig('hrlTfinal.pdf', bbox_inches='tight', transparent=True, dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
