{
 "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": "markdown",
   "metadata": {},
   "source": [
    "# Hyper-representation with two-layers net "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/bookAir/anaconda3/envs/cv/lib/python3.6/site-packages/torch/nn/functional.py:1805: UserWarning: nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\n",
      "  warnings.warn(\"nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\")\n"
     ]
    }
   ],
   "source": [
    "p, q, d, n = 256, 512, 256, 5000 # CG was not working with n=10000 \n",
    "m = 0.1 \n",
    "\n",
    "Xg = torch.randn((n, p)) # data \n",
    "H1_true = torch.randn((p, q)) # layer 1\n",
    "H2_true = torch.randn((q, d)) # layer 2\n",
    "w_true = torch.randn(d) # final regression layer\n",
    "\n",
    "yg = F.sigmoid(F.sigmoid(Xg @ H1_true) @ H2_true) @ w_true + m * torch.randn(n)\n",
    "Xf = torch.randn((n, p))\n",
    "yf = F.sigmoid(F.sigmoid(Xf @ H1_true) @ H2_true) @ w_true + m * torch.randn(n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "b = 0.001\n",
    "\n",
    "def hypernet(hparams, X): \n",
    "    H1 = hparams[0]\n",
    "    H2 = hparams[1]\n",
    "    out = F.sigmoid(F.sigmoid(X @ H1) @ H2) \n",
    "    \n",
    "    return out\n",
    "\n",
    "def regressor(params, Z, y):\n",
    "    w = params[0]\n",
    "    loss = (torch.norm(Z @ w - y))**2\n",
    "    \n",
    "    return loss\n",
    "    \n",
    "def inner_func(params, hparams):\n",
    "    w = params[0]\n",
    "    #sigmoid\n",
    "    Zg = hypernet(hparams, Xg)\n",
    "    lg = regressor(params, Zg, yg)\n",
    "    g = 0.5 * lg / n + 0.5 * b * (torch.norm(w))**2\n",
    "   \n",
    "    return g #.squeeze()\n",
    "\n",
    "def outer_func(params, hparams):\n",
    "    w = params[0]\n",
    "    #sigmoid\n",
    "    Zf = hypernet(hparams, Xf)\n",
    "    lf = regressor(params, Zf, yf)\n",
    "    f = 0.5 * lf / n\n",
    "    \n",
    "    return f #.squeeze()\n",
    "\n",
    "###########################################################\n",
    "alpha = .001\n",
    "p0 = [torch.randn(d)]\n",
    "hp0 = [torch.randn((p, q)), torch.randn((q, 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",
    "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",
    "    Zg = hypernet(hparams, Xg)\n",
    "    for _ in range(steps):\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": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/bookAir/anaconda3/envs/cv/lib/python3.6/site-packages/torch/nn/functional.py:1805: UserWarning: nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\n",
      "  warnings.warn(\"nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (3.97e-01s)(1.31e-01, 2.61e-01) | val loss=37.435218811035156 | hypergrad norm = 3.016e+00\n",
      "outer step=10 (3.19e-01s)(7.45e-02, 2.43e-01) | val loss=4.190017223358154 | hypergrad norm = 6.736e-01\n",
      "outer step=20 (3.28e-01s)(7.77e-02, 2.49e-01) | val loss=0.6471925973892212 | hypergrad norm = 2.244e-01\n",
      "outer step=30 (3.19e-01s)(7.60e-02, 2.42e-01) | val loss=0.2297997772693634 | hypergrad norm = 1.580e-01\n",
      "outer step=40 (3.18e-01s)(7.53e-02, 2.42e-01) | val loss=0.07659881561994553 | hypergrad norm = 9.074e-02\n",
      "outer step=50 (3.34e-01s)(7.54e-02, 2.57e-01) | val loss=0.021810512989759445 | hypergrad norm = 4.235e-02\n",
      "outer step=60 (3.38e-01s)(9.32e-02, 2.44e-01) | val loss=0.0072416868060827255 | hypergrad norm = 2.243e-02\n",
      "outer step=70 (3.34e-01s)(7.74e-02, 2.56e-01) | val loss=0.0029536623042076826 | hypergrad norm = 1.367e-02\n",
      "outer step=80 (3.28e-01s)(7.83e-02, 2.49e-01) | val loss=0.00132969138212502 | hypergrad norm = 8.252e-03\n",
      "outer step=90 (3.35e-01s)(8.04e-02, 2.54e-01) | val loss=0.0006106175133027136 | hypergrad norm = 4.916e-03\n",
      "outer step=99 (3.21e-01s)(7.61e-02, 2.44e-01) | val loss=0.00030450348276644945 | hypergrad norm = 3.281e-03\n",
      "total time = 32.752166509628296\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 = .1\n",
    "beta = .01\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(running_time, val_losses)\n",
    "#plt.savefig('plots/val_loss2.png', bbox_inches='tight')\n",
    "#plt.close()\n",
    "plt.show()\n",
    "\n",
    "norm_zoj = hg_norms\n",
    "val_zoj = val_losses\n",
    "run_zoj = running_time\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/bookAir/anaconda3/envs/cv/lib/python3.6/site-packages/torch/nn/functional.py:1805: UserWarning: nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\n",
      "  warnings.warn(\"nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (4.99e-01s)(1.18e-01, 3.79e-01) | val loss=30.493314743041992 | hypergrad norm = 5.132e+00\n",
      "outer step=10 (4.57e-01s)(9.16e-02, 3.65e-01) | val loss=13.894075393676758 | hypergrad norm = 2.575e+00\n",
      "outer step=20 (4.57e-01s)(9.10e-02, 3.65e-01) | val loss=4.814870357513428 | hypergrad norm = 1.118e+00\n",
      "outer step=30 (4.87e-01s)(1.02e-01, 3.84e-01) | val loss=1.8685228824615479 | hypergrad norm = 5.534e-01\n",
      "outer step=40 (4.58e-01s)(9.08e-02, 3.66e-01) | val loss=0.7942010164260864 | hypergrad norm = 3.530e-01\n",
      "outer step=50 (4.64e-01s)(9.05e-02, 3.72e-01) | val loss=0.3077293932437897 | hypergrad norm = 2.120e-01\n",
      "outer step=60 (4.58e-01s)(9.08e-02, 3.66e-01) | val loss=0.13997264206409454 | hypergrad norm = 1.388e-01\n",
      "outer step=70 (4.57e-01s)(9.09e-02, 3.65e-01) | val loss=0.06603782624006271 | hypergrad norm = 9.673e-02\n",
      "outer step=80 (4.78e-01s)(9.46e-02, 3.82e-01) | val loss=0.052640050649642944 | hypergrad norm = 9.832e-02\n",
      "outer step=90 (4.84e-01s)(9.92e-02, 3.83e-01) | val loss=0.040735796093940735 | hypergrad norm = 8.149e-02\n",
      "outer step=99 (4.58e-01s)(9.13e-02, 3.66e-01) | val loss=0.029204202815890312 | hypergrad norm = 6.678e-02\n",
      "total time = 46.55131244659424\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 = 30 # did not work with 10\n",
    "beta = 0.01\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(running_time, val_losses)\n",
    "#plt.savefig('plots/val_loss2.png', bbox_inches='tight')\n",
    "#plt.close()\n",
    "plt.show()\n",
    "norm_cg = hg_norms\n",
    "val_cg = val_losses\n",
    "run_cg = running_time\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/bookAir/anaconda3/envs/cv/lib/python3.6/site-packages/torch/nn/functional.py:1805: UserWarning: nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\n",
      "  warnings.warn(\"nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (4.49e-01s)(1.06e-01, 3.41e-01) | val loss=37.435218811035156 | hypergrad norm = 3.075e+00\n",
      "outer step=10 (4.27e-01s)(7.81e-02, 3.48e-01) | val loss=3.508333683013916 | hypergrad norm = 6.299e-01\n",
      "outer step=20 (4.31e-01s)(7.51e-02, 3.55e-01) | val loss=0.5191173553466797 | hypergrad norm = 2.118e-01\n",
      "outer step=30 (4.26e-01s)(7.52e-02, 3.50e-01) | val loss=0.18181048333644867 | hypergrad norm = 1.496e-01\n",
      "outer step=40 (4.14e-01s)(7.47e-02, 3.39e-01) | val loss=0.054309528321027756 | hypergrad norm = 8.001e-02\n",
      "outer step=50 (4.51e-01s)(8.63e-02, 3.63e-01) | val loss=0.01580842211842537 | hypergrad norm = 3.895e-02\n",
      "outer step=60 (4.17e-01s)(7.55e-02, 3.41e-01) | val loss=0.006608482450246811 | hypergrad norm = 2.746e-02\n",
      "outer step=70 (4.17e-01s)(7.50e-02, 3.41e-01) | val loss=0.0026582321152091026 | hypergrad norm = 1.820e-02\n",
      "outer step=80 (4.20e-01s)(7.65e-02, 3.42e-01) | val loss=0.0010267894249409437 | hypergrad norm = 1.117e-02\n",
      "outer step=90 (4.23e-01s)(7.57e-02, 3.46e-01) | val loss=0.000395612558349967 | hypergrad norm = 6.752e-03\n",
      "outer step=99 (4.85e-01s)(9.27e-02, 3.91e-01) | val loss=0.00015375710790976882 | hypergrad norm = 4.081e-03\n",
      "total time = 42.27633237838745\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",
    "beta = 0.01 \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(running_time, val_losses)\n",
    "#plt.savefig('plots/val_loss2.png', bbox_inches='tight')\n",
    "#plt.close()\n",
    "plt.show()\n",
    "\n",
    "norm_fp = hg_norms\n",
    "val_fp = val_losses\n",
    "run_fp = running_time\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/bookAir/anaconda3/envs/cv/lib/python3.6/site-packages/torch/nn/functional.py:1805: UserWarning: nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\n",
      "  warnings.warn(\"nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (3.42e-01s)(1.16e-01, 2.24e-01) | val loss=37.435218811035156 | hypergrad norm = 3.746e-02\n",
      "outer step=10 (3.03e-01s)(8.04e-02, 2.22e-01) | val loss=31.94343376159668 | hypergrad norm = 2.861e-03\n",
      "outer step=20 (3.05e-01s)(7.69e-02, 2.26e-01) | val loss=29.827478408813477 | hypergrad norm = 4.120e-03\n",
      "outer step=30 (3.29e-01s)(9.31e-02, 2.35e-01) | val loss=29.301755905151367 | hypergrad norm = 5.932e-03\n",
      "outer step=40 (2.94e-01s)(7.70e-02, 2.16e-01) | val loss=28.997909545898438 | hypergrad norm = 4.215e-03\n",
      "outer step=50 (3.05e-01s)(7.88e-02, 2.25e-01) | val loss=28.672510147094727 | hypergrad norm = 1.907e-03\n",
      "outer step=60 (3.00e-01s)(7.64e-02, 2.23e-01) | val loss=27.923328399658203 | hypergrad norm = 5.302e-03\n",
      "outer step=70 (2.99e-01s)(7.76e-02, 2.20e-01) | val loss=28.146406173706055 | hypergrad norm = 8.869e-03\n",
      "outer step=80 (3.00e-01s)(7.69e-02, 2.22e-01) | val loss=28.167743682861328 | hypergrad norm = 1.272e-02\n",
      "outer step=90 (3.10e-01s)(8.91e-02, 2.20e-01) | val loss=27.829103469848633 | hypergrad norm = 4.311e-03\n",
      "outer step=99 (3.18e-01s)(7.96e-02, 2.37e-01) | val loss=27.5342960357666 | hypergrad norm = 9.499e-03\n",
      "total time = 30.88194179534912\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 = 0.1\n",
    "beta = .2\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",
    "        #print('suboptimality (H - H*) = {:.3e} | suboptimality (w - w*) = {:.3e} | hypergrad norm = {:.3e}'.format(torch.norm(hparams[0] - H_true, 'fro'), torch.norm(params[0] - w_true), torch.norm(hparams[0].grad)))\n",
    "\n",
    "\n",
    "\n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "plt.plot(running_time, val_losses)\n",
    "#plt.savefig('plots/val_loss2.png', bbox_inches='tight')\n",
    "#plt.close()\n",
    "plt.show()\n",
    "\n",
    "norm_hozog = hg_norms\n",
    "val_hozog = val_losses\n",
    "run_hozog = running_time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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1sydO7fM31drTWJiIqdPn2bfvn3Mnz+fkSNH0qBBA1q3bs2KFSvK7L1XrVpF48aN6dq1K9OmTWP37t1ERUWRlpZGUlISJ0+eZMWKFbz++uvUrl2b7t2788cff1zznosXL+a2226je/fuRERE8Msvv3D69GlSU1NJTU0lOjqanTt38tlnn9G7d29CQ0MZOXIk58+fL7Ofs6zYVQcSCAYStNYJReyvkVIhTsXH040AHw/iUzLIyNLEJKcT4u/a+yD5d7qXi9OnA5D0889Y09OxeHqaHJUoC8E+wcy8b2aeepF/XvqT8OXhvN/mfe6qcZfJEQohhBDl69tvvyUxMTFP25dffmmMHJamRx99lPDwcOM8LS2NS5cucerUKXbu3MmWLVtIT09n+/btdOvWjQEDBjBjxgw8PDxKLYYJEyYwduxYYxlL1apV6dKlC82bNyc0NJSsrCyio6PZtm0b69atIzExkeXLl5OUlMSmTZuuul9mZibDhw9nxowZRltISAgdO3akefPmBAcH4+npycWLFzl69CibNm1i7969JCcnM2XKFLKysoiIiCi1n6882JtAxgNVlVJeWuu0a3VUSlUDAoDTxQ1OmKNaZW/iUzIAWykPV08gvW69FY+aNck4fRprcjKXd+7E7557Cr9QOKWcdZH1g+rz9o63ybBmGPUih90+jP4N+pf6/zCFEEIIRzVnzhwAPDw86N27N/Pnz+fEiRNs2LCBjh07lup71a1blx49ehT4+tmzZ3n//feZNm0aWmu++OILrFYrM2fOLJX3/+CDDxgzZgwAFouF119/nVGjRuHn55dv/+TkZKZPn857771X4D1ffPFFPvnkEwC8vLx45513eOGFF/D29i7wmsOHDzN16lRmzZpVgp/GPPaODu7FtgayXRH6Pp/9vNPO9xAmq5Z7J9YKsA5SKSXTWCugh295mC+7fGmsi9Ropu2ZJusihRBCVBjHjh1j82bb/g9dunThpZdeMl7LSSzLU/Xq1Zk6dSpLliwxfpk7a9YsFixYUOJ779y5k1dffRWwffdbsGABb731VoHJI4Cvry+jR4/mt99+o1mzZle9vmTJEiN59Pb2Zv369bz00kvXTB4B6tSpw2effcauXbto2LBhCX4qc9ibQM7DlkC+q5QKKKiTUqov8Dq2Kayzix+eMEPudZDR8SkmRlJ+cu/GmrhhAzor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BI37+0rH1/p7qH58rdfY/IVIc/fh1p9ha72vEkN77O2v61StFkN9/8CBh9l/wQUtx5vPYZXfxUaGCqz6ujq/fFXtcZzQZXmV88eBX2yu28QXU9nIuPbaS09+opzU6fB/bL8kkPUWxhNntwjG2s4TERHpe2bpZDuZXkeyvfzRLNdedmoLfots1F13fZ9rr72k12GIdF2/rG5d75i91r/iH0jLtcZIioiIiIiIyEn0SwJ5Z1o+z8xaXpOZjQLXAMvAP3Y7MBERERERkX7RFwmkuz8IfBK4AHh12+FbgGHgz7UGpIiIiIiIyOb1yxhIgFcB9wLvMrPnAN8Eng5cR+i6+us9jE1EREREROSM1xctkNBohbwSuJ2QOL4WuAh4F3CVu0/3LjoREREREZEzXz+1QOLujwAv63UcIiIiIiIi/ahvWiBFRERERERkeymBFBERERERkY4ogRQREREREZGOKIEUERERERGRjiiBFBERERERkY4ogRQREREREZGOKIEUERERERGRjiiBFBERERERkY4ogRQREREREZGOKIEUERERERGRjiiBFBERERERkY6Yu/c6htOKmR0FDm7DrfcAx7bhviLr0ftOekHvO+k2veekF/S+k17o1vtuv7tPrnZACWSXmNkX3f3KXschO4ved9ILet9Jt+k9J72g9530wunwvlMXVhEREREREemIEkgRERERERHpiBLI7rm11wHIjqT3nfSC3nfSbXrPSS/ofSe90PP3ncZAioiIiIiISEfUAikiIiIiIiIdUQIpIiIiIiIiHVECuY3M7Dwz+zMze9TMymZ2wMzeYWa7eh2b9Ccz+1kze7eZfc7M5szMzeyDvY5L+peZ7Tazl5vZR8zsATNbNrOimd1tZr9gZvp/RraFmf2emX3GzB5J33fHzexfzOyNZra71/HJzmBmL03/r3Uze3mv45H+k+YPvsZ2qCcxaQzk9jCzi4B7gSngb4BvAU8DrgO+DVzj7tO9i1D6kZl9GXgKsAB8D7gM+At3f0lPA5O+ZWavBP4EeAy4E/gusBe4ARgH/hp4kes/G9liZlYB/hn4BnAEGAaeAVwJPAo8w90f6V2E0u/M7HHAV4EMMAK8wt1v621U0m/M7AAwAbxjlcML7v4H3Y0Ist1+wh3kPYTk8WZ3f3e90szeDvwK8BbglT2KTfrXrxASxweAZxM+0Its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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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\n",
      "text/plain": [
       "<Figure size 1080x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# range to plot (for zooming in)\n",
    "s1 = 35\n",
    "s2 = 60\n",
    "s3 = 35\n",
    "\n",
    "# s1 = 100\n",
    "# s2 = 100\n",
    "# s3 = 100\n",
    "\n",
    "lw = 3\n",
    "iters = list(range(K))\n",
    "plt.plot(run_zoj[:s2+12], val_zoj[:s2+12], '-', label='ESJ', linewidth=lw)\n",
    "plt.plot(run_hozog[:s2], val_hozog[:s2], '-', label='HOZOG', linewidth=lw)\n",
    "plt.plot(run_cg[:s1], val_cg[:s1], '-', label='AID-CG', linewidth=lw)\n",
    "plt.plot(run_fp[:s3], val_fp[:s3], '-', 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.legend(loc='center right', fontsize=30)\n",
    "plt.grid()\n",
    "plt.gcf().set_size_inches(15, 8)\n",
    "#plt.savefig('hr2ln.pdf', bbox_inches='tight', transparent=True, dpi=600)\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[:s1], norm_cg[:s1], '-', label='AIG-CG', linewidth=lw)\n",
    "plt.plot(run_fp[:s3], norm_fp[:s3], '-', 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('deepHR_mnist.pdf', bbox_inches='tight', transparent=True, dpi=600)\n",
    "#plt.savefig('hr2ln_grad.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": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/bookAir/anaconda3/envs/cv/lib/python3.6/site-packages/torch/nn/functional.py:1805: UserWarning: nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\n",
      "  warnings.warn(\"nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\")\n"
     ]
    }
   ],
   "source": [
    "p, q, d, n = 256, 512, 256, 5000 \n",
    "m = 0.1 \n",
    "\n",
    "Xg = torch.randn((n, p)) # data \n",
    "H1_true = torch.randn((p, q)) # layer 1\n",
    "H2_true = torch.randn((q, d)) # layer 2\n",
    "w_true = torch.randn(d) # final regression layer\n",
    "\n",
    "yg = F.sigmoid(F.sigmoid(Xg @ H1_true) @ H2_true) @ w_true + m * torch.randn(n)\n",
    "Xf = torch.randn((n, p))\n",
    "yf = F.sigmoid(F.sigmoid(Xf @ H1_true) @ H2_true) @ w_true + m * torch.randn(n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "b = 0.001\n",
    "\n",
    "def hypernet(hparams, X): \n",
    "    H1 = hparams[0]\n",
    "    H2 = hparams[1]\n",
    "    out = F.sigmoid(F.sigmoid(X @ H1) @ H2) \n",
    "    \n",
    "    return out\n",
    "\n",
    "def regressor(params, Z, y):\n",
    "    w = params[0]\n",
    "    loss = (torch.norm(Z @ w - y))**2\n",
    "    \n",
    "    return loss\n",
    "    \n",
    "def inner_func(params, hparams):\n",
    "    w = params[0]\n",
    "    #sigmoid\n",
    "    Zg = hypernet(hparams, Xg)\n",
    "    lg = regressor(params, Zg, yg)\n",
    "    g = 0.5 * lg / n + 0.5 * b * (torch.norm(w))**2\n",
    "   \n",
    "    return g #.squeeze()\n",
    "\n",
    "def outer_func(params, hparams):\n",
    "    w = params[0]\n",
    "    #sigmoid\n",
    "    Zf = hypernet(hparams, Xf)\n",
    "    lf = regressor(params, Zf, yf)\n",
    "    f = 0.5 * lf / n\n",
    "    \n",
    "    return f #.squeeze()\n",
    "\n",
    "###########################################################\n",
    "alpha = .0003\n",
    "p0 = [torch.randn(d)]\n",
    "hp0 = [torch.randn((p, q)), torch.randn((q, 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",
    "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",
    "    Zg = hypernet(hparams, Xg)\n",
    "    for _ in range(steps):\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"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "T = 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/bookAir/anaconda3/envs/cv/lib/python3.6/site-packages/torch/nn/functional.py:1805: UserWarning: nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\n",
      "  warnings.warn(\"nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (3.47e-01s)(1.05e-01, 2.40e-01) | val loss=46.34346008300781 | hypergrad norm = 3.333e+00\n",
      "outer step=10 (3.07e-01s)(6.99e-02, 2.36e-01) | val loss=5.652091979980469 | hypergrad norm = 8.122e-01\n",
      "outer step=20 (3.06e-01s)(6.99e-02, 2.36e-01) | val loss=0.8814826011657715 | hypergrad norm = 2.508e-01\n",
      "outer step=30 (3.07e-01s)(7.04e-02, 2.36e-01) | val loss=0.409040242433548 | hypergrad norm = 2.039e-01\n",
      "outer step=40 (3.07e-01s)(7.00e-02, 2.36e-01) | val loss=0.15993773937225342 | hypergrad norm = 1.304e-01\n",
      "outer step=50 (3.09e-01s)(7.11e-02, 2.37e-01) | val loss=0.0448027178645134 | hypergrad norm = 6.092e-02\n",
      "outer step=60 (3.09e-01s)(7.04e-02, 2.38e-01) | val loss=0.014876265078783035 | hypergrad norm = 2.892e-02\n",
      "outer step=70 (3.09e-01s)(7.07e-02, 2.37e-01) | val loss=0.006633054465055466 | hypergrad norm = 1.675e-02\n",
      "outer step=80 (3.10e-01s)(7.04e-02, 2.39e-01) | val loss=0.0031318531837314367 | hypergrad norm = 1.103e-02\n",
      "outer step=90 (3.12e-01s)(7.06e-02, 2.40e-01) | val loss=0.001722167362459004 | hypergrad norm = 8.409e-03\n",
      "outer step=99 (3.11e-01s)(7.15e-02, 2.39e-01) | val loss=0.0008867771248333156 | hypergrad norm = 4.950e-03\n",
      "total time = 31.02932047843933\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 = 5\n",
    "mu = .1\n",
    "beta = .01\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(running_time, val_losses)\n",
    "#plt.savefig('plots/val_loss2.png', bbox_inches='tight')\n",
    "#plt.close()\n",
    "plt.show()\n",
    "\n",
    "norm_zoj5 = hg_norms\n",
    "val_zoj5 = val_losses\n",
    "run_zoj5 = running_time\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "T = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/bookAir/anaconda3/envs/cv/lib/python3.6/site-packages/torch/nn/functional.py:1805: UserWarning: nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\n",
      "  warnings.warn(\"nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (3.50e-01s)(1.06e-01, 2.42e-01) | val loss=37.435218811035156 | hypergrad norm = 3.016e+00\n",
      "outer step=10 (3.17e-01s)(7.46e-02, 2.42e-01) | val loss=4.187587738037109 | hypergrad norm = 6.733e-01\n",
      "outer step=20 (3.18e-01s)(7.45e-02, 2.42e-01) | val loss=0.6485164165496826 | hypergrad norm = 2.246e-01\n",
      "outer step=30 (3.18e-01s)(7.47e-02, 2.42e-01) | val loss=0.23038049042224884 | hypergrad norm = 1.579e-01\n",
      "outer step=40 (3.21e-01s)(7.53e-02, 2.44e-01) | val loss=0.07708700001239777 | hypergrad norm = 9.077e-02\n",
      "outer step=50 (3.19e-01s)(7.48e-02, 2.43e-01) | val loss=0.022075597196817398 | hypergrad norm = 4.244e-02\n",
      "outer step=60 (3.19e-01s)(7.44e-02, 2.44e-01) | val loss=0.0073136016726493835 | hypergrad norm = 2.248e-02\n",
      "outer step=70 (3.19e-01s)(7.47e-02, 2.44e-01) | val loss=0.0029676028061658144 | hypergrad norm = 1.370e-02\n",
      "outer step=80 (3.22e-01s)(7.47e-02, 2.46e-01) | val loss=0.0012657700572162867 | hypergrad norm = 8.370e-03\n",
      "outer step=90 (3.29e-01s)(7.54e-02, 2.53e-01) | val loss=0.00048079309635795653 | hypergrad norm = 4.896e-03\n",
      "outer step=99 (3.24e-01s)(7.65e-02, 2.47e-01) | val loss=0.00020030667656101286 | hypergrad norm = 3.198e-03\n",
      "total time = 32.087770223617554\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 = .1\n",
    "beta = .01\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(running_time, val_losses)\n",
    "#plt.savefig('plots/val_loss2.png', bbox_inches='tight')\n",
    "#plt.close()\n",
    "plt.show()\n",
    "\n",
    "norm_zoj10 = hg_norms\n",
    "val_zoj10 = val_losses\n",
    "run_zoj10 = running_time\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "T = 20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/bookAir/anaconda3/envs/cv/lib/python3.6/site-packages/torch/nn/functional.py:1805: UserWarning: nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\n",
      "  warnings.warn(\"nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (4.23e-01s)(1.65e-01, 2.57e-01) | val loss=31.710590362548828 | hypergrad norm = 2.789e+00\n",
      "outer step=10 (3.33e-01s)(8.30e-02, 2.49e-01) | val loss=2.946906805038452 | hypergrad norm = 5.549e-01\n",
      "outer step=20 (3.36e-01s)(8.47e-02, 2.50e-01) | val loss=0.4375735819339752 | hypergrad norm = 1.996e-01\n",
      "outer step=30 (3.37e-01s)(8.42e-02, 2.52e-01) | val loss=0.12945161759853363 | hypergrad norm = 1.202e-01\n",
      "outer step=40 (3.37e-01s)(8.24e-02, 2.54e-01) | val loss=0.03934400528669357 | hypergrad norm = 6.374e-02\n",
      "outer step=50 (3.35e-01s)(8.27e-02, 2.52e-01) | val loss=0.018117085099220276 | hypergrad norm = 4.557e-02\n",
      "outer step=60 (3.38e-01s)(8.38e-02, 2.53e-01) | val loss=0.005917677190154791 | hypergrad norm = 2.527e-02\n",
      "outer step=70 (3.44e-01s)(8.37e-02, 2.59e-01) | val loss=0.0022658391389995813 | hypergrad norm = 1.561e-02\n",
      "outer step=80 (3.38e-01s)(8.37e-02, 2.53e-01) | val loss=0.0012254954781383276 | hypergrad norm = 1.269e-02\n",
      "outer step=90 (3.43e-01s)(8.50e-02, 2.57e-01) | val loss=0.00036103709135204554 | hypergrad norm = 6.657e-03\n",
      "outer step=99 (3.42e-01s)(8.38e-02, 2.58e-01) | val loss=0.00017917594232130796 | hypergrad norm = 4.645e-03\n",
      "total time = 33.90521740913391\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 = .1\n",
    "beta = .01\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(running_time, val_losses)\n",
    "#plt.savefig('plots/val_loss2.png', bbox_inches='tight')\n",
    "#plt.close()\n",
    "plt.show()\n",
    "\n",
    "norm_zoj20 = hg_norms\n",
    "val_zoj20 = val_losses\n",
    "run_zoj20 = running_time\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "T = 50"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/bookAir/anaconda3/envs/cv/lib/python3.6/site-packages/torch/nn/functional.py:1805: UserWarning: nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\n",
      "  warnings.warn(\"nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outer step=0 (4.27e-01s)(1.48e-01, 2.78e-01) | val loss=35.201416015625 | hypergrad norm = 2.900e+00\n",
      "outer step=10 (3.81e-01s)(1.06e-01, 2.74e-01) | val loss=4.135444164276123 | hypergrad norm = 6.379e-01\n",
      "outer step=20 (3.85e-01s)(1.07e-01, 2.76e-01) | val loss=0.7821059226989746 | hypergrad norm = 2.553e-01\n",
      "outer step=30 (3.96e-01s)(1.15e-01, 2.80e-01) | val loss=0.25412413477897644 | hypergrad norm = 1.502e-01\n",
      "outer step=40 (3.89e-01s)(1.13e-01, 2.75e-01) | val loss=0.08439497649669647 | hypergrad norm = 8.047e-02\n",
      "outer step=50 (3.91e-01s)(1.15e-01, 2.75e-01) | val loss=0.03342216834425926 | hypergrad norm = 4.267e-02\n",
      "outer step=60 (4.10e-01s)(1.15e-01, 2.94e-01) | val loss=0.018710225820541382 | hypergrad norm = 3.023e-02\n",
      "outer step=70 (3.99e-01s)(1.20e-01, 2.78e-01) | val loss=0.010638625361025333 | hypergrad norm = 1.641e-02\n",
      "outer step=80 (3.90e-01s)(1.08e-01, 2.81e-01) | val loss=0.007284758612513542 | hypergrad norm = 1.086e-02\n",
      "outer step=90 (3.95e-01s)(1.15e-01, 2.79e-01) | val loss=0.005053512752056122 | hypergrad norm = 7.044e-03\n",
      "outer step=99 (3.91e-01s)(1.09e-01, 2.82e-01) | val loss=0.003729281947016716 | hypergrad norm = 4.806e-03\n",
      "total time = 39.04357576370239\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 = 50\n",
    "mu = .1\n",
    "beta = .01\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(running_time, val_losses)\n",
    "#plt.savefig('plots/val_loss2.png', bbox_inches='tight')\n",
    "#plt.close()\n",
    "plt.show()\n",
    "\n",
    "norm_zoj50 = hg_norms\n",
    "val_zoj50 = val_losses\n",
    "run_zoj50 = running_time\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "run_zoj5 = [t / 4 for t in run_zoj10]\n",
    "run_zoj10 = [t / 4 for t in run_zoj10]\n",
    "run_zoj20 = [t / 4 for t in run_zoj20]\n",
    "run_zoj50 = [t / 4 for t in run_zoj50]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA5MAAAH6CAYAAACaixgyAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJzs3Xl8VNX9//HXSTLZE5YQwhIxLJIgCAhBBFHjzmIpKLi01lrX37fSKra2tmpLW62t9eu+V2q/WuoCZXFFRI2ogAhiAUnYwioEwhayL5Pz+2OGyWQlQyaZSfJ+Ph7zmHPuPffez9Sr5cM993OMtRYRERERERERX4QEOgARERERERFpe5RMioiIiIiIiM+UTIqIiIiIiIjPlEyKiIiIiIiIz5RMioiIiIiIiM+UTIqIiIiIiIjPlEyKiIiIiIiIz5RMioiIiIiIiM+UTIqIiIiIiIjPwgIdQLDp1q2bTUlJCXQY0oEVFRURExMT6DCkA9E9J61J95u0Nt1zIr5bs2bNQWtt4onGKZmsJSUlhdWrVwc6DOnAMjMzycjICHQY0oHonpPWpPtNWpvuORHfGWN2NmWcprmKiIiIiIiIz5RMioiIiIiIiM+UTIqIiIiIiIjPlEyKiIiIiIiIz5RMioiIiIiIiM+UTIqIiIiIiIjPlEyKiIiIiIiIz5RMioiIiIiIiM+UTIqIiIiIiIjPlEyKiIiIiIiIz5RMioiIiIiIiM+UTIqIiIiIiIjPlEyKiIiIiIiIz5RMioiIiIiIiM+CNpk0xvzVGPORMWa3MabEGHPYGLPWGPN7Y0xCrbEpxhjbyOf1QP0OERERERGR9igs0AE0YibwNfAhcACIAc4GZgG3GmPOttburnXMf4GF9ZxrQwvG2SqqiooIiYkJdBgiIiIiIiJAcCeT8dba0tobjTEPAr8FfgP8tNbub6y1s1ohtlZz8MW/U/jJJ5SsW8eAj5bi6NEj0CGJiIiIiIgE7zTX+hJJtzfd36e1ViyBVLR8OSVr14LTSdGKlYEOR0REREREBAjiZLIR33N/r6tnXy9jzG3GmN+6v4e2ZmAtIWbsWE+7aPnyAEYiIiIiIiJSLZinuQJgjPklEAt0AtKBcbgSyb/UM/wS98f7+Ezgx9baXS0bacuIGTuWvEcfBaBoxQqstRhjAhyViIiIiIh0dMZaG+gYGmWMyQWSvDYtBm6w1u73GtMdmIGr+E6Oe/NQXMV6LgC2AsOttUUNXONW4FaApKSkka+/HkTFX6uqSLz7V4QUuUI/dN+9VCYnBzgoaUmFhYXExsYGOgzpQHTPSWvS/SatTfeciO8uuOCCNdba9BONC/pk8jhjTBIwFtcTyTjgcmvt1yc4Jgz4HBgN3GmtfeJE10lPT7erV6/2Q8T+s+fOmRQsXgxA91/9ioQbfxLgiKQlZWZmkpGREegwpAPRPSetSfebtDbdcyK+M8Y0KZlsM+9MWmv3W2sXAJcCCcArTTimEnjJ3T2vBcNrUTFjx3jaRStWBDASERERERERlzaTTB5nrd0JbAQGG2O6NeGQPPd3m12kMWbsOZ528VdfUVVeHsBoRERERERE2mAy6dbL/e1swtiz3d85jY4KYuHJvXH06QOALS2l5Ou1AY5IREREREQ6uqBMJo0xacaYHvVsDzHGPAh0B5Zba4+4t482xoTXM/5CYKa7+6+WjLml1ZjqqiVCREREREQkwIJ1aZDxwN+MMcuAbcAhXBVdzwf6AbnALV7j/4pr2msmsMe9bShwobt9v7W2TWdgMWPHcvT1N4Dj703ObPwAERERERGRFhSsyeRS4EXgHGAY0BkoAjYDrwJPWmsPe41/FZgKjAImAA5gP/Am8LS19rPWC71lxIweDSEhUFVF6YYNOI8eJbRz50CHJSIiIiIiHVRQJpPW2g3A7T6Mnw3MbrmIAi+0UycihwyhdN06sJailV8SP/6yQIclIiIiIiIdVFC+Myn103uTIiIiIiISLJRMtiExY8d62lpvUkREREREAknJZBsSPXw4JioKgIrduynfvTvAEYmIiIiISEelZLINMeHhRI9K9/SLvtBUVxERERERCQwlk21Mjamuem9SREREREQCRMlkG1MjmfzyS6zTGcBoRERERESko1Iy2cZEnHYaoYndAKjKz6d048YARyQiIiIiIh2Rksk2xhhDzBivJUL03qSIiIiIiASAksk2SO9NioiIiIhIoCmZbINixlQnkyVr11JVXBzAaEREREREpCNSMtkGOZK6E3HaAABsRQXFa9YEOCIREREREelolEy2UdF6b1JERERERAJIyWQbpfcmRUREREQkkJRMtlExo0aBwwFA2ebNVOblBTgisNay+3AxH27czz8+3x7ocERERERE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\n",
      "text/plain": [
       "<Figure size 1080x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "s1 = 24\n",
    "s2 = 30\n",
    "\n",
    "lw = 3\n",
    "iters = list(range(K))\n",
    "plt.plot(run_zoj5[2:s2], val_zoj5[2:s2], '-', label='ESJ-5', linewidth=lw)\n",
    "plt.plot(run_zoj10[1:s2], val_zoj10[1:s2], '-', 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_fp[:s1], val_fp[:s1], '-', label='AID-FP', linewidth=lw)\n",
    "plt.plot(run_zoj50[:s1], val_zoj50[:s1], '-', label='ESJ-50', linewidth=lw)\n",
    "plt.xlabel('Running time', fontsize=24)\n",
    "plt.ylabel('Outer loss', fontsize=24)\n",
    "plt.xticks([0.5, 1, 1.5, 2], 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('hr2lnTfinal.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
}
