{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "270de681-4957-4fd3-b489-17436c76c43a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "from tqdm.notebook import tqdm as tqdm\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "outputs": [],
   "source": [
    "# return a flat vector from a tuple of vectors and matrices.\n",
    "def tuple_to_vector(tuple_in):\n",
    "    return torch.cat([t.view(-1) for t in tuple_in])\n",
    "\n",
    "def tuple_numel(tuple_in):\n",
    "    return [t.numel() for t in tuple_in]\n",
    "\n",
    "# return a tuple of vectors from a flat vec\n",
    "def rollup_vector(flat_vector, tuple_in):\n",
    "    new_vec = torch.split(flat_vector, tuple_numel(tuple_in))\n",
    "    return [v.view_as(t) for v, t in zip(new_vec, tuple_in)]"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5feb7a69-533a-4fa8-827e-ecc194da45d2",
   "metadata": {},
   "outputs": [],
   "source": [
    "def f(x, y, A, b):\n",
    "    rho = 1 / (20 * x.shape[0])\n",
    "    return rho / 6 * np.linalg.norm(x) ** 3 + \\\n",
    "    (A @ x - b) @ y\n",
    "\n",
    "\n",
    "def fx(x, y, A, b):\n",
    "    rho = 1 / (20 * x.shape[0])\n",
    "    return rho / 2 * np.linalg.norm(x) * x + A.T @ y\n",
    "\n",
    "\n",
    "def fy(x, y, A, b):\n",
    "    return A @ x - b\n",
    "\n",
    "\n",
    "def F(x, y, A, b):\n",
    "    return fx(x, y, A, b), -fy(x, y, A, b)\n",
    "\n",
    "\n",
    "def F_joint(z, A, b):\n",
    "    n = b.shape[0]\n",
    "    Fx, Fy = F(z[:n], z[n:], A, b)\n",
    "    return np.concatenate([Fx, Fy], axis=0)\n",
    "\n",
    "\n",
    "def J_joint(z, A, b):\n",
    "    n = b.shape[0]\n",
    "    rho = 1 / (20 * b.shape[0])\n",
    "    x = z[:n]\n",
    "    y = z[n:]\n",
    "    J11 = rho / 2 * np.linalg.norm(x) * np.eye(n) + rho / 2 / (np.linalg.norm(x) + 1e-9) * np.outer(x, x)\n",
    "    J12 = A.T\n",
    "    J21 = -A\n",
    "    J22 = np.zeros_like(A)\n",
    "    J1 = np.concatenate([J11, J12], axis=1)\n",
    "    J2 = np.concatenate([J21, J22], axis=1)\n",
    "    return np.concatenate([J1, J2], axis=0)\n",
    "\n",
    "\n",
    "def x_y_opt(A, b):\n",
    "    rho = 1 / (20 * b.shape[0])\n",
    "    x_opt = np.linalg.inv(A) @ b\n",
    "    y_opt = -rho / 2 * np.linalg.norm(x_opt) * np.linalg.inv(A.T) @ x_opt\n",
    "    return x_opt, y_opt\n",
    "\n",
    "\n",
    "def gap(x, y, A, b, R):\n",
    "    rho = 1 / (20 * b.shape[0])\n",
    "    return rho / 6 * np.linalg.norm(x) ** 3 + R * np.linalg.norm(A @ x - b) + \\\n",
    "    2/3 * np.sqrt(2 / rho) * np.linalg.norm(A.T @ y) ** 1.5 + b @ y\n",
    "\n",
    "\n",
    "def extragrad_opt(A, b, lr, n_steps, R, return_avg=False):\n",
    "    x_0 = np.zeros_like(b)\n",
    "    y_0 = np.zeros_like(b)\n",
    "    gaps = [gap(x_0, y_0, A, b, R)]\n",
    "    x_sum = np.zeros_like(x_0)\n",
    "    y_sum = np.zeros_like(y_0)\n",
    "    x_t = x_0\n",
    "    y_t = y_0\n",
    "    F_evals = 0\n",
    "    for j in tqdm(range(n_steps)):\n",
    "        F_tx, F_ty = F(x_t, y_t, A, b)\n",
    "        F_evals += 1\n",
    "        x_aux, y_aux = x_t - lr * F_tx, y_t - lr * F_ty\n",
    "        F_tx, F_ty = F(x_aux, y_aux, A, b)\n",
    "        F_evals += 1\n",
    "        x_t, y_t = x_t - lr * F_tx, y_t - lr * F_ty\n",
    "        x_sum += x_t\n",
    "        y_sum += y_t\n",
    "        x_avg = x_sum / (j + 1)\n",
    "        y_avg = y_sum / (j + 1)\n",
    "        gaps.append(gap(x_t if not return_avg else x_avg,\n",
    "                        y_t if not return_avg else y_avg, A, b, R))\n",
    "    return {'gaps': gaps, 'F_evals': F_evals}\n",
    "        \n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "508f3fe1-d4ef-40a9-9736-01a8e29ac949",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "  0%|          | 0/20000 [00:00<?, ?it/s]",
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "4f59bea90e584ef3a36aa33ab6c7b435"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'F_evals': 40000}\n"
     ]
    }
   ],
   "source": [
    "n = 50\n",
    "lr = .5\n",
    "R = 1.0\n",
    "A = np.eye(n)\n",
    "for i in range(n - 1):\n",
    "    A[i, i + 1] = -1\n",
    "b = np.zeros(n)\n",
    "b[0] = 1  # NOTE: was in the original paper\n",
    "out = extragrad_opt(A, b, lr, 20000, R, return_avg=False)\n",
    "print({k: v for k, v in out.items() if k != 'gaps'})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ad70659a-f07a-4085-964f-87ff99349273",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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e+t3lIiIiNoctw+EysrKEBUVheTkZIfvr1q1CklJSViwYAF27dqFqKgoxMfHIycnp5V7emmYESIiInIdvas70JiJEydi4sSJTt9//fXXMWvWLMycORMAsHz5cqxZswYffPAB5s6de9H3q6qqQlVVlfS6uLj44jt9ERgHERERuY7bZ4QaUl1djZ07dyIuLk46ptVqERcXh61bt17SNRcvXgw/Pz/pKyIiorm66xDjICIiItdp04FQXl4eLBYLQkJCFMdDQkKQlZUlvY6Li8Ptt9+OtWvXomvXrg0GSfPmzUNRUZH0dfr06RbrP8ChMSIiIldy+6Gx5rB+/fomtzWZTDCZTEhOTkZycjIsFksL9oxDY0RERK7UpjNCQUFB0Ol0yM7OVhzPzs5GaGjoZV07MTER6enp2LFjx2VdpzEWLi1NRETkMm06EDIajRg+fDhSUlKkY1arFSkpKRg1apQLe9Z0DISIiIhcx+2HxkpLS5GRkSG9zszMRFpaGgIDA9GtWzckJSUhISEBI0aMQExMDJYuXYqysjJpFtmlaq2hMdYIERERuY7bB0KpqamYMGGC9DopKQkAkJCQgBUrVmD69OnIzc3F/PnzkZWVhejoaKxbt86ugPpiJSYmIjExEcXFxfDz87usazWEGSEiIiLXcftAaPz48RAayZrMnj0bs2fPbtb7MiNERETU/rXpGqGW1FrF0kwIERERuQ4DIRdjRoiIiMh1GAi5GGuEiIiIXIeBkBPJyckYMGAARo4c2aL3sTIQIiIichkGQk602oKKHBojIiJyGQZCLma1uroHREREHRcDIRdjsTQREZHrMBByorVqhDg0RkRE5DoMhJxorRohxkFERESuw0CIiIiIOiwGQkRERNRhMRByorVqhIiIiMh1GAg50Vo1QkREROQ6DISIiIiow2IgRERERB0WAyEiIiLqsBgIERERUYfFQMgJzhojIiJq/xgIOcFZY0RERO0fAyEiIiLqsBgIERERUYfFQIiIiIg6LAZCRERE1GExEHIRrcbVPSAiIiIGQi5i1PNHT0RE5Gr8NHYRo44/eiIiIlfjp7ETLb2golGva5HrEhERUdMxEHKipRdUNHFojIiIyOX4aewirBEiIiJyPX4auwhrhIiIiFyPn8YuIs8IWayCC3tCRETUcTEQchF5IFRda3VhT4iIiDouBkIuYtDVr6jI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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(out['gaps'])\n",
    "plt.yscale('log')\n",
    "plt.xlabel('iteration')\n",
    "plt.ylabel('Gap')\n",
    "plt.title('EG1 (w/o averaging)')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "6e12080d",
   "metadata": {},
   "outputs": [],
   "source": [
    "EG1 = out['gaps']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "fc1794cb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch.optim.optimizer import Optimizer\n",
    "\n",
    "\n",
    "class Perseus(Optimizer):\n",
    "    def __init__(self,\n",
    "                 params,\n",
    "                 L: float = 1., p_order: int = 2, last_iterate: bool = True,\n",
    "                 verbose: bool = True, testing: bool = False\n",
    "                 ):\n",
    "        super().__init__(params, dict(L=L))\n",
    "\n",
    "        self.verbose = verbose\n",
    "        self.testing = testing\n",
    "\n",
    "        self.last_iterate = last_iterate\n",
    "        self.p_order = p_order\n",
    "        self.L = L\n",
    "\n",
    "        if len(self.param_groups) != 1:\n",
    "            raise ValueError(\"Perseus doesn't support per-parameter options \"\n",
    "                             \"(parameter groups)\")\n",
    "        group = self.param_groups[0]\n",
    "        params = group['params']\n",
    "        p = next(iter(params))\n",
    "        state_common = self.state[p]\n",
    "        state_common['k'] = 0\n",
    "\n",
    "        if not self.last_iterate:\n",
    "            state_common['lambda_sum'] = 0.\n",
    "\n",
    "        # Initialization of intermediate points\n",
    "        for p in params:\n",
    "            state = self.state[p]\n",
    "            state['x0'] = p.detach().clone()\n",
    "            state['x'] = state['x0'].clone()\n",
    "            state['v'] = state['x0'].clone()\n",
    "            state['s'] = torch.zeros_like(state['x'])\n",
    "            if not self.last_iterate:\n",
    "                state['x_average'] = torch.zeros_like(p)\n",
    "\n",
    "    # lambda_computation\n",
    "    @torch.no_grad()\n",
    "    def compute_lambda(self, L, params):\n",
    "        bound = (1 / (20 * self.p_order - 8) + 1 / (10 * self.p_order + 2)) / 2\n",
    "        den = 1\n",
    "        for m in range(1, self.p_order + 1):\n",
    "            den *= m\n",
    "        norm = 0.\n",
    "        with torch.no_grad():\n",
    "            for p in params:\n",
    "                state = self.state[p]\n",
    "                norm += (p - state['v']).square().sum()\n",
    "        return bound * den / (L * norm ** (self.p_order - 1))\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def full_inverse_vector(self, A, b, tau):\n",
    "        return torch.linalg.inv(A + torch.diag(torch.ones_like(b)).mul_(tau)) @ b\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def subproblem_solver(self, A, b, L, inverse_vector, tau_up=0.01, tau_low=0., max_iter=20):\n",
    "\n",
    "        j = 0\n",
    "        flag = True\n",
    "        while flag and j < max_iter:\n",
    "            h = - inverse_vector(A, b, 5 * L * tau_up)\n",
    "            norm = torch.linalg.norm(h).item()\n",
    "            if norm > tau_up:\n",
    "                tau_up *= 2\n",
    "            else:\n",
    "                flag = False\n",
    "            j += 1\n",
    "\n",
    "        j = 0\n",
    "        h = torch.zeros_like(b)\n",
    "        norm = 0.\n",
    "        criteria = 100.\n",
    "        while j < max_iter and criteria > L / 2 * norm ** 2:\n",
    "            tau = (tau_up + tau_low) / 2\n",
    "            h = - inverse_vector(A, b, 5 * L * tau)\n",
    "            norm = torch.linalg.norm(h).item()\n",
    "            if norm < tau:\n",
    "                tau_up = tau + 0.\n",
    "            else:\n",
    "                tau_low = tau + 0.\n",
    "            j += 1\n",
    "            c = b + A @ h + 5 * L * torch.linalg.norm(h) * h\n",
    "            criteria = torch.norm(c)\n",
    "        return h  # , criteria\n",
    "\n",
    "    # step 3\n",
    "    def second_order_step(self, params, operator_v):\n",
    "        operator_vec = tuple_to_vector(operator_v)\n",
    "        # print('operator', operator_vec)\n",
    "        # print('params', params)\n",
    "        A = self.jacobian(params, operator_vec)\n",
    "        b = operator_vec.detach().clone()\n",
    "        # print(A)\n",
    "        h = self.subproblem_solver(A, b, L=self.L, inverse_vector=self.full_inverse_vector)\n",
    "        h_tuple = rollup_vector(h, list(params))\n",
    "        with torch.no_grad():\n",
    "            for p, z in zip(params, h_tuple):\n",
    "                p.add_(z)\n",
    "\n",
    "    def jacobian(self, params, operator_vector):\n",
    "        full_jacobian = []\n",
    "        for g in operator_vector:\n",
    "            temp_jvp = torch.autograd.grad(g, params, retain_graph=True)\n",
    "            full_jacobian.append(tuple_to_vector(temp_jvp))\n",
    "        return torch.stack(full_jacobian)\n",
    "\n",
    "    def step(self, closure):\n",
    "\n",
    "        closure = torch.enable_grad()(closure)\n",
    "\n",
    "        assert len(self.param_groups) == 1\n",
    "        group = self.param_groups[0]\n",
    "        params = group['params']\n",
    "        p = next(iter(params))\n",
    "        state_common = self.state[p]\n",
    "\n",
    "        # step 2\n",
    "        with torch.no_grad():\n",
    "            for p in params:\n",
    "                state = self.state[p]\n",
    "                state['v'] = state['x0'] + state['s']  # / self.L\n",
    "                p.zero_().add_(state['v'])\n",
    "\n",
    "        operator_v = closure()\n",
    "        if self.p_order == 1:\n",
    "            with torch.no_grad():\n",
    "                for p, g in zip(params, operator_v):\n",
    "                    state = self.state[p]\n",
    "                    p.sub_(g / self.L / 5)\n",
    "                    state['x'] = p.clone()\n",
    "        elif self.p_order == 2:\n",
    "            self.second_order_step(params, operator_v)\n",
    "            with torch.no_grad():\n",
    "                for p in params:\n",
    "                    state = self.state[p]\n",
    "                    state['x'] = p.clone()\n",
    "\n",
    "        lamb = self.compute_lambda(self.L, params)\n",
    "        operator_x = closure()\n",
    "\n",
    "        if not self.last_iterate:\n",
    "            state_common['lambda_sum'] += lamb\n",
    "\n",
    "        with torch.no_grad():\n",
    "            for p, g in zip(params, operator_x):\n",
    "                state = self.state[p]\n",
    "                state['s'].sub_(g, alpha=lamb)\n",
    "\n",
    "                if not self.last_iterate:\n",
    "                    state['x_average'].mul_(state_common['lambda_sum']).add_(state['x'] * lamb)\n",
    "                    state_common['lambda_sum'] += lamb\n",
    "                    state['x_average'].div_(state_common['lambda_sum'])\n",
    "                    p.zero_().add_(state['x_average'])\n",
    "\n",
    "        state_common['k'] += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "52ab517f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def norm(x):\n",
    "    return x.square().sum() ** 0.5\n",
    "\n",
    "def fx_torch(param, A, b):\n",
    "    x, y = param\n",
    "    rho = 1 / (20 * x.shape[0])\n",
    "    return rho / 2 * torch.linalg.norm(x) * x + A.T @ y\n",
    "\n",
    "\n",
    "def fy_torch(param, A, b):\n",
    "    x, y = param\n",
    "    return A @ x - b\n",
    "\n",
    "\n",
    "def F_torch(param, A, b):\n",
    "    return fx_torch(param, A, b), -fy_torch(param, A, b)\n",
    "\n",
    "def gap_torch(param, A, b, R):\n",
    "    x, y = param\n",
    "    rho = 1 / (20 * b.shape[0])\n",
    "    return rho / 6 * norm(x) ** 3 + R * norm(A @ x - b) + \\\n",
    "    2/3 * np.sqrt(2 / rho) * torch.linalg.norm(A.T @ y) ** 1.5 + b @ y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "cb40fa58",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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BiQioobO4YERJJkA2JvxRrVEDEhERA3cg1Ns9uYqKOT8aiDifwVERA3cgyNGbNAm0mFAIiJq4JQKmX6DSe6iTaTDgERERHAouicbG7SJdBiQiIhIP3LEgFR3VPsNhXl/4hIYkIiICEM8nNHExgT92zhIXQqRQeCtRoiICCO8XDDCy0XqMogMBkeQiIiI6jBRfNLXP+Eb1FMMSERERESlMCARERERlcKARERERFQKAxIRERFRKQxIRERERKUwIBERERGVwoBEREREVAoDEhEREVEpDEhEREREpTAgEREREZXCgERERERUCgMSERERUSkMSERERESlKKQuoK4qvvtxenq6xJUQEVFDlJ2ZAW1eNvJzVBV+F+VmZUKblw2g4u+rjAzdORpB3iC+04p/x+Lv8YoI4qPOoHLdvHkTrq6uUpdBREREVRAXFwcXF5cKn2dAqiKtVov4+HiYm5tDEIRqe9/09HS4uroiLi4OFhYW1fa+VD5e79rDa117eK1rD6917amuay2KIjIyMuDs7AyZrOJOI06xVZFMJnto8nxSFhYW/I+tFvF61x5e69rDa117eK1rT3Vca0tLy0eewyZtIiIiolIYkIiIiIhKYUAyMCqVCrNmzYJKpZK6lAaB17v28FrXHl7r2sNrXXtq+1qzSZuIiIioFI4gEREREZXCgERERERUCgMSERERUSkMSERERESlMCAZmJCQELi5uUGtVsPX1xdHjx6VuqQ6b+7cuejatSvMzc3h4OCAoUOH4sKFCyXOyc3NxZQpU2BrawszMzOMGDECiYmJElVcf/z3v/+FIAh499139cd4ravPrVu38Oqrr8LW1hbGxsbo2LEjIiMj9c+LoohPP/0UjRo1grGxMfz8/HDp0iUJK66bNBoNPvnkEzRr1gzGxsZo0aIFvvjiixL38uK1rprw8HAMHjwYzs7OEAQBmzdvLvF8Za7r3bt3MWbMGFhYWMDKygpvvPEGMjMzn7g2BiQDsnbtWgQFBWHWrFk4fvw4PDw84O/vj6SkJKlLq9P27duHKVOm4PDhw9i5cycKCgrwzDPPICsrS3/Oe++9hz///BPr16/Hvn37EB8fj+HDh0tYdd137NgxLF68GJ06dSpxnNe6ety7dw89e/aEkZER/v77b5w7dw7ff/89rK2t9ed88803mDdvHhYtWoQjR47A1NQU/v7+yM3N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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "A_torch = torch.tensor(A)\n",
    "b_torch = torch.tensor(b)\n",
    "x = torch.zeros_like(b_torch, requires_grad=True)\n",
    "y = torch.zeros_like(b_torch, requires_grad=True)\n",
    "param = [x,y]\n",
    "optimizer = Perseus(param, L=1.e-4, p_order=2, last_iterate=True)\n",
    "gaps = []\n",
    "iters = 0\n",
    "while iters < 100:\n",
    "    def closure():\n",
    "        optimizer.zero_grad()\n",
    "        return F_torch(param, A_torch, b_torch)\n",
    "    func_loss = gap_torch(param, A_torch, b_torch, R)\n",
    "    gaps.append(func_loss.item())\n",
    "\n",
    "    optimizer.step(closure)\n",
    "    iters += 1\n",
    "\n",
    "plt.plot(gaps)\n",
    "plt.title('Perseus 2 order')\n",
    "plt.yscale('log')\n",
    "plt.xlabel('iteration')\n",
    "plt.ylabel('Gap')\n",
    "plt.show()\n",
    "\n",
    "PERSEUS2 = gaps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "bdd6b77b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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gxARERF1WgxCRERE1GkxCBEREVGnxSCkocqaeq1vgYiIqFNjENLIK98dQ/8Fa7H7bIHWt0JERNRpMQhp5N3NZwAAr609rvGdEBERdV4MQhrjut5ERETaYRDSGHMQERGRdhiEiIiIqNNiENIY97wlIiLSDoOQxhiDiIiItMMgRERERJ0Wg5DGODJGRESkHQYhjTEHERERaYdBSGssCREREWmGQYiIiIg6LQYhIiIi6rQYhDTGgTEiIiLtMAgRERFRp8UgpDH2ShMREWmHQUhjAgfHiIiINMMgpDFWhIiIiLTDIERERESdFoOQxlgRIiIi0g6DkMaYg4iIiLTDIERERESdFoMQERERdVoMQhoT2CRERESkGQYhIiIi6rQYhIiIiKjTYhDSGEfGiIiItMMgpDFusUFERKQdBiEiIiLqtBiENMahMSIiIu0wCGmMOYiIiEg7DEJERETUaTEIERERUafFIKQxrixNRESkHQYhjTEGERERaYdBSGMsCBEREWmHQUhjdiYhIiIizTAIaYxBiIiISDsMQhqz27W+AyIios6LQYiIiIg6LQYhjXFojIiISDsMQhpjECIiItIOg5DG7MxBREREmmEQ0hgLQkRERNphENIckxAREZFWGIQ0xqExIiIi7TAIaYzN0kRERNphENKYnSUhIiIizTAIaYwFISIiIu0wCGmMOYiIiEg7DEIaY48QERGRdhiENMYgREREpB0GIY2xV5qIiEg7DEJaYxAiIiLSDIOQxgQmISIiIs0wCGmMQ2NERETaYRDSGJuliYiItNMpgtA333yDvn37onfv3vjXv/6l9e0oMAcRERFpx6j1DbS0uro6zJs3Dxs3bkRwcDBGjBiB22+/HeHh4VrfGhEREWmsw1eEdu3ahYEDB6JLly4ICAjA5MmT8cMPP2h9W0RERNQGtPkgtHnzZkyZMgVxcXHQ6XRYvXq1xzlLly5FYmIirFYrUlJSsGvXLum1ixcvokuXLtLzLl264MKFC61x60RERNTGtfkgVF5ejqSkJCxdutTr6ytXrsS8efPw/PPPY9++fUhKSsLEiRORm5vbyndKRERE7U2bD0KTJ0/GSy+9hNtvv93r64sXL8acOXMwa9YsDBgwAMuWLYPNZsN7770HAIiLi1NUgC5cuIC4uDjVz6uurkZJSYniDxEREXVMbT4INaSmpgZ79+7FhAkT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99578eKLL2LixIkIDg7GihUr8Ne//rVF7tNkMime63Q62O32FvksImo6BiEiarPMZjPq6+sVx4YPH46jR4+iV69el/Ve27dvR7du3fD//t//k45lZGQ0+nnu+vfvj+XLl6O8vFwKW9u2bYNer0ffvn0v656ISHtsliaiNisxMRGbN2/GhQsXkJ+fD8Ax82v79u2YO3cuUlNTcerUKaxZs8ajWdld7969ce7cOaxYsQKnT5/G3//+d3z11Vcen5eeno7U1FTk5+ejurra433uvfdeWK1WzJgxA4cPH8bGjRvxu9/9Dvfdd580LEZE7QeDEBG1WQsXLsTZs2fRs2dPREZGAgCGDBmCTZs24eTJkxgzZgyGDRuGBQsWIC4ursH3mjp1Kn7/+99j7ty5GDp0KLZv3y7NJhPdeeedmDRpEsaPH4/IyEh89tlnHu9js9mwbt06FBQU4KqrrsKvf/1r3HDDDXjrrbea74sTUavhytJERETUabEiRERERJ0WgxARERF1WgxCRERE1GkxCBEREVGnxSBEREREnRaDEBEREXVaDEJERETUaTEIERERUafFIERERESdFoMQERERdVoMQkRERNRpMQgRERFRp/X/AeHPRDDgCoPmAAAAAElFTkSuQmCC\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "A_torch = torch.tensor(A)\n",
    "b_torch = torch.tensor(b)\n",
    "x = torch.zeros_like(b_torch, requires_grad=True)\n",
    "y = torch.zeros_like(b_torch, requires_grad=True)\n",
    "param = [x,y]\n",
    "optimizer = Perseus(param, L=0.2334, p_order=1, last_iterate=True)\n",
    "gaps = []\n",
    "iters = 0\n",
    "while iters < 20000:\n",
    "    def closure():\n",
    "        optimizer.zero_grad()\n",
    "        return F_torch(param, A_torch, b_torch)\n",
    "    func_loss = gap_torch(param, A_torch, b_torch, R)\n",
    "    gaps.append(func_loss.item())\n",
    "\n",
    "    optimizer.step(closure)\n",
    "    iters += 1\n",
    "\n",
    "plt.plot(gaps)\n",
    "plt.title('Perseus 1 order')\n",
    "plt.yscale('log')\n",
    "plt.xlabel('iteration')\n",
    "plt.ylabel('Gap')\n",
    "plt.show()\n",
    "\n",
    "PERSEUS1 = gaps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "514823a6",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.optim.optimizer import Optimizer\n",
    "class VIQA(Optimizer):\n",
    "    def __init__(self,\n",
    "                    params,\n",
    "                    L: float = 1., delta: float = 0., B0: float = 0., memory: int = 10, p_order: int = 1, last_iterate: bool = True,\n",
    "                 verbose: bool = True, testing: bool = False, qn = 'Broyd_damped', half = 1\n",
    "                ):\n",
    "        super().__init__(params, dict(L=L))\n",
    "\n",
    "        self.verbose = verbose\n",
    "        self.testing = testing\n",
    "        self.qn = qn\n",
    "        self.half = half\n",
    "\n",
    "        self.last_iterate = last_iterate\n",
    "        self.p_order = p_order\n",
    "        self.L = L\n",
    "        self.delta = delta\n",
    "        self.B0 = B0\n",
    "        self.memory = memory\n",
    "\n",
    "        if len(self.param_groups) != 1:\n",
    "            raise ValueError(\"VIQA doesn't support per-parameter options \"\n",
    "                             \"(parameter groups)\")\n",
    "        group = self.param_groups[0]\n",
    "        params = group['params']\n",
    "        p = next(iter(params))\n",
    "        state_common = self.state[p]\n",
    "        state_common['k'] = 0\n",
    "        state_common['S_qn'] = []\n",
    "        state_common['Y_qn'] = []\n",
    "\n",
    "        if not self.last_iterate:\n",
    "            state_common['lambda_sum'] = 0.\n",
    "\n",
    "        # Initialization of intermediate points\n",
    "        for p in params:\n",
    "            state = self.state[p]\n",
    "            state['x0'] = p.detach().clone()\n",
    "            state['x'] = state['x0'].clone()\n",
    "            state['v'] = state['x0'].clone()\n",
    "            state['s'] = torch.zeros_like(state['x'])\n",
    "\n",
    "            if not self.last_iterate:\n",
    "                state['x_average'] = torch.zeros_like(p)\n",
    "\n",
    "    #lambda_computation\n",
    "    @torch.no_grad()\n",
    "    def compute_lambda(self, L, params, delta=0.):\n",
    "        bound = (1 / (20 * self.p_order - 8) + 1 / (10 * self.p_order + 2)) / 2\n",
    "        den = 1\n",
    "        for m in range(1, self.p_order+1):\n",
    "            den *= m\n",
    "        norm = 0.\n",
    "        with torch.no_grad():\n",
    "            for p in params:\n",
    "                state = self.state[p]\n",
    "                norm += (p - state['v']).square().sum()**.5\n",
    "        return  bound / (L * norm ** (self.p_order-1)/den + delta)\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def full_inverse_vector(self, A, b, tau):\n",
    "        return torch.linalg.inv(A + torch.diag(torch.ones_like(b)).mul_(tau)) @ b\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def subproblem_solver(self, A, b, L, inverse_vector, delta=0., tau_up = 0.01 , tau_low = 0., max_iter = 20):\n",
    "\n",
    "        j = 0\n",
    "        flag = True\n",
    "        while flag and j < max_iter:\n",
    "            h = - inverse_vector(A,b,5 * L * tau_up + delta)\n",
    "            norm = torch.linalg.norm(h).item()\n",
    "            if norm > tau_up:\n",
    "                tau_up *= 2\n",
    "            else:\n",
    "                flag = False\n",
    "            j+=1\n",
    "\n",
    "        j = 0\n",
    "        h = torch.zeros_like(b)\n",
    "        norm = 0.\n",
    "        criteria = 100.\n",
    "        while j < max_iter and criteria > L / 2 * norm ** 2: #and abs(tau - norm) > 0.001\n",
    "            tau = (tau_up + tau_low) / 2\n",
    "            h = - inverse_vector(A,b,5*L/2*tau+ delta)\n",
    "            norm = torch.linalg.norm(h).item()\n",
    "            #print(tau, norm)\n",
    "            if norm < tau:\n",
    "                tau_up = tau + 0.5\n",
    "            else:\n",
    "                tau_low = tau + 0.5\n",
    "            j += 1\n",
    "            c = b + A @ h + 5 * L / 2 * torch.linalg.norm(h) * h + delta * h\n",
    "            criteria = torch.norm(c)\n",
    "        return h#, criteria\n",
    "\n",
    "    def Broyd_qn(self, params, S, Y, B0):\n",
    "        V_qn = []\n",
    "        C_qn = []\n",
    "        U_qn = []\n",
    "        g = tuple_to_vector(list(params))\n",
    "        B = torch.diag(torch.ones_like(g)).mul_(B0)\n",
    "\n",
    "        if len(S) == 0:\n",
    "            return V_qn, C_qn, U_qn, B\n",
    "\n",
    "        for i in range(len(S)):\n",
    "            s = tuple_to_vector(S[-1-i])\n",
    "            v = s.clone()\n",
    "            y = tuple_to_vector(Y[-1-i])\n",
    "            u = y - B @ s\n",
    "            c = 1/v.mul(v).sum()\n",
    "            C_qn.insert(0, c)\n",
    "            V_qn.insert(0, v)\n",
    "            U_qn.insert(0, u)\n",
    "            B += u.outer(v) * c\n",
    "        return V_qn, C_qn, U_qn, B\n",
    "    \n",
    "    def Broyd_qn_damped(self, params, S, Y, B0, memory):\n",
    "        V_qn = []\n",
    "        C_qn = []\n",
    "        U_qn = []\n",
    "        g = tuple_to_vector(list(params))\n",
    "        B = torch.diag(torch.ones_like(g)).mul_(B0)\n",
    "\n",
    "        if len(S) == 0:\n",
    "            return V_qn, C_qn, U_qn, B\n",
    "\n",
    "        for i in range(len(S)):\n",
    "            s = tuple_to_vector(S[-1-i])\n",
    "            v = s.clone()\n",
    "            y = tuple_to_vector(Y[-1-i])\n",
    "            u = y - B @ s\n",
    "            c = 1/(v.mul(v).sum() * (memory + 1))\n",
    "            C_qn.insert(0, c)\n",
    "            V_qn.insert(0, v)\n",
    "            U_qn.insert(0, u)\n",
    "            B += u.outer(v) * c\n",
    "        return V_qn, C_qn, U_qn, B\n",
    "    \n",
    "    def BFGS_qn(self, params, S, Y, B0, memory = 0):\n",
    "        V_qn = []\n",
    "        C_qn = []\n",
    "        U_qn = []\n",
    "        g = tuple_to_vector(list(params))\n",
    "        B = torch.diag(torch.ones_like(g)).mul_(B0)\n",
    "\n",
    "        if len(S) == 0:\n",
    "            return V_qn, C_qn, U_qn, B\n",
    "\n",
    "        for i in range(1, len(S)):\n",
    "            s = tuple_to_vector(S[-1-i])\n",
    "            y = tuple_to_vector(Y[-1-i])\n",
    "\n",
    "            #part 1\n",
    "            c1 = 1/(y.mul(s).sum() * (memory + 1))\n",
    "            C_qn.insert(0, c1)\n",
    "            V_qn.insert(0, s)\n",
    "            U_qn.insert(0, y)\n",
    "\n",
    "\n",
    "            #part 2\n",
    "            u = B @ s\n",
    "            c2 = - 1 / s.mul(u).sum()\n",
    "            C_qn.insert(0, c2)\n",
    "            V_qn.insert(0, u)\n",
    "            U_qn.insert(0, u)\n",
    "            B += u.outer(u) * c2\n",
    "            B += y.outer(y) * c1\n",
    "\n",
    "\n",
    "        return V_qn, C_qn, U_qn, B\n",
    "\n",
    "    #step 3\n",
    "    def qn_step(self, params, operator_v, S, Y, B0=0):\n",
    "        b = tuple_to_vector(operator_v).detach().clone()\n",
    "\n",
    "        if self.qn == 'Broyd_damped':\n",
    "            V_qn, C_qn, U_qn, B = self.Broyd_qn_damped(params, S, Y, B0, memory=self.memory)\n",
    "        elif self.qn == 'BFGS':\n",
    "            V_qn, C_qn, U_qn, B = self.BFGS_qn(params, S, Y, B0, memory=0)\n",
    "        elif self.qn == 'BFGS_broid':\n",
    "            V_qn, C_qn, U_qn, B1 = self.BFGS_qn(params, S, Y, B0, memory=0)\n",
    "            V_qn, C_qn, U_qn, B2 = self.Broyd_qn(params, S, Y, B0)\n",
    "            B = (B1 + B2) / (1 + self.half)\n",
    "        elif self.qn == 'BFGS_damped':\n",
    "            V_qn, C_qn, U_qn, B1 = self.BFGS_qn(params, S, Y, B0, memory=0)\n",
    "            V_qn, C_qn, U_qn, B2 = self.Broyd_qn_damped(params, S, Y, B0, memory=0)\n",
    "            B = (B1 + B2) / (1 + self.half)\n",
    "\n",
    "        elif self.qn == 'damped_BFGS':\n",
    "            V_qn, C_qn, U_qn, B = self.BFGS_qn(params, S, Y, B0, memory=self.memory)\n",
    "        elif self.qn == 'damped_BFGS_broid':\n",
    "            V_qn, C_qn, U_qn, B1 = self.BFGS_qn(params, S, Y, B0, memory=self.memory)\n",
    "            V_qn, C_qn, U_qn, B2 = self.Broyd_qn(params, S, Y, B0)\n",
    "            B = (B1 + B2) / (1 + self.half)\n",
    "        elif self.qn == 'damped_BFGS_damped':\n",
    "            V_qn, C_qn, U_qn, B1 = self.BFGS_qn(params, S, Y, B0, memory=self.memory)\n",
    "            V_qn, C_qn, U_qn, B2 = self.Broyd_qn_damped(params, S, Y, B0, memory=self.memory)\n",
    "            B = (B1 + B2) / (1 + self.half)\n",
    "        elif self.qn == 'broyd':\n",
    "            V_qn, C_qn, U_qn, B = self.Broyd_qn(params, S, Y, B0)\n",
    "        else:\n",
    "            raise ValueError\n",
    "        h = self.subproblem_solver(B, b, L = self.L, delta = self.delta, inverse_vector = self.full_inverse_vector)\n",
    "        h_tuple = rollup_vector(h, list(params))\n",
    "        return h_tuple\n",
    "\n",
    "    def jacobian(self, params, operator_vector):\n",
    "        full_jacobian = []\n",
    "        for g in operator_vector:\n",
    "            temp_jvp = torch.autograd.grad(g, params, retain_graph=True)\n",
    "            full_jacobian.append(tuple_to_vector(temp_jvp))\n",
    "        return torch.stack(full_jacobian)\n",
    "\n",
    "\n",
    "    def step(self, closure):\n",
    "\n",
    "        closure = torch.enable_grad()(closure)\n",
    "\n",
    "        assert len(self.param_groups) == 1\n",
    "        group = self.param_groups[0]\n",
    "        params = group['params']\n",
    "        p = next(iter(params))\n",
    "        state_common = self.state[p]\n",
    "\n",
    "\n",
    "        #step 2\n",
    "        with torch.no_grad():\n",
    "            for p in params:\n",
    "                state = self.state[p]\n",
    "                state['v'] = state['x0'] + state['s']\n",
    "                p.zero_().add_(state['v'])\n",
    "\n",
    "        operator_v = closure()\n",
    "\n",
    "\n",
    "\n",
    "        h_tuple = self.qn_step(params, operator_v, S = state_common['S_qn'], Y = state_common['Y_qn'], B0 = self.B0)\n",
    "\n",
    "        state_common['S_qn'].insert(0, h_tuple)\n",
    "        if len(state_common['S_qn']) > self.memory:\n",
    "            state_common['S_qn'].pop()\n",
    "\n",
    "\n",
    "        with torch.no_grad():\n",
    "            for p, z in zip(params,h_tuple):\n",
    "                state = self.state[p]\n",
    "                p.add_(z)\n",
    "                state['x'] = p.clone().detach()\n",
    "\n",
    "\n",
    "        with torch.no_grad():\n",
    "            for p in params:\n",
    "                state = self.state[p]\n",
    "                state['x'] = p.clone()\n",
    "\n",
    "        lamb = self.compute_lambda(self.L, params, delta=self.delta)\n",
    "        operator_x = closure()\n",
    "\n",
    "        oper_dif = []\n",
    "        with torch.no_grad():\n",
    "            for g2, g1 in zip(operator_x,operator_v):\n",
    "                oper_dif.append(g2-g1)\n",
    "\n",
    "        state_common['Y_qn'].insert(0, oper_dif)\n",
    "        if len(state_common['Y_qn']) > self.memory:\n",
    "            state_common['Y_qn'].pop()\n",
    "\n",
    "\n",
    "        if not self.last_iterate:\n",
    "            state_common['lambda_sum'] += lamb\n",
    "\n",
    "\n",
    "        with torch.no_grad():\n",
    "            for p, g in zip(params, operator_x):\n",
    "                state = self.state[p]\n",
    "                state['s'].sub_(g, alpha = lamb)\n",
    "\n",
    "                if not self.last_iterate:\n",
    "                    state['x_average'].mul_(state_common['lambda_sum']).add_(state['x'] * lamb)\n",
    "                    state_common['lambda_sum'] += lamb\n",
    "                    state['x_average'].div_(state_common['lambda_sum'])\n",
    "                    p.zero_().add_(state['x_average'])\n",
    "\n",
    "        state_common['k'] += 1\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "0b48dbdc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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LCyEjY0NHB0d4efnh2effdZgwei1117Dpk2bNM9cq5WbmwtXV1ejeeo3EemOtdQFEBHdzs3NTef7rKqqgq2tbau3N/QT14nIcHhpjIiMSu2lsWHDhuHChQt47rnnIJPJIJPJNG327t2LIUOGwN7eHj4+PnjmmWdQXl6uWe/n54c333wTDz/8MJycnPDYY48BAF588UX07NkTDg4O8Pf3x6uvvqp5eveaNWvw+uuv49ixY5rjrVmzBkDdS2MnTpzAiBEjYG9vjw4dOuCxxx5DWVmZZv2MGTMwYcIELF26FF5eXujQoQPi4+O1nhRORMaBQYiIjNKPP/6ILl264I033sDVq1dx9epVAMC5c+cwatQo3HvvvTh+/DjWr1+PvXv3Yvbs2VrbL126FCEhITh69CheffVVAICjoyPWrFmD9PR0/Pvf/8Ynn3yCDz74AAAwefJkPP/88+jTp4/meJMnT65TV3l5OWJiYuDq6opDhw5hw4YN2LFjR53j79y5E+fOncPOnTvxxRdfYM2aNZpgRUTGg5fGiMgoubm5QS6Xw9HRUevS1KJFizBt2jTNuKGAgAAsX74cd911F1auXAk7OzsAwIgRI/D8889r7fOVV17R/Ozn54cXXngB69atw7x582Bvb4/27dvD2tq60Utha9euRUVFBb788ku0a9cOALBixQqMHTsW//rXv+Dh4QEAcHV1xYoVKyCXy9GrVy+MGTMGSUlJmDVrlk7+fIhINxiEiMikHDt2DMePH8c333yjWSaEgFqtRlZWFnr37g0AGDhwYJ1t169fj+XLl+PcuXMoKytDTU0NnJycWnT8U6dOISQkRBOCAODOO++EWq1GRkaGJgj16dMHcrlc08bLywsnTpxo0bGISP8YhIjIpJSVleHxxx/HM888U2edr6+v5ufbgwoApKSkYNq0aXj99dcRExMDZ2dnrFu3Du+9955e6rSxsdF6L5PJoFar9XIsImo9BiEiMlq2trZQqVRaywYMGID09HT06NGjRfvav38/unbtipdfflmz7MKFC00e7+969+6NNWvWoLy8XBO29u3bBysrKwQGBraoJiKSHgdLE5HR8vPzQ3JyMi5fvoyCggIAt+782r9/P2bPno20tDScPXsWmzdvrjNY+e8CAgJw8eJFrFu3DufOncPy5cuxcePGOsfLyspCWloaCgoKUFlZWWc/06ZNg52dHeLi4nDy5Ens3LkTTz/9NKZPn665LEZEpoNBiIiM1htvvIHs7Gx0794dHTt2BAD069cPu3fvxpkzZzBkyBD0798fCxYsgLe3d6P7GjduHJ577jnMnj0boaGh2L9/v+Zuslr33nsvRo0aheHDh6Njx4749ttv6+zHwcEB27dvR2FhIcLDw3Hfffdh5MiRWLFihe5OnIgMhjNLExERkcVijxARERFZLAYhIiIislgMQkRERGSxGISIiIjIYjEIERERkcViECIiIiKLxSBEREREFotBiIiIiCwWgxARERFZLAYhIiIislgMQkRERGSxGISIiIjIYv0/B94vftnaO78AAAAASUVORK5CYII=\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "n = 50\n",
    "A = np.eye(n)\n",
    "for i in range(n - 1):\n",
    "    A[i, i + 1] = -1\n",
    "b = np.zeros(n)\n",
    "b[0] = 1  # NOTE: was in the original paper\n",
    "A_torch = torch.tensor(A)\n",
    "b_torch = torch.tensor(b)\n",
    "x = torch.zeros_like(b_torch, requires_grad=True)\n",
    "y = torch.zeros_like(b_torch, requires_grad=True)\n",
    "param = [x,y]\n",
    "optimizer = VIQA(param, L=.1e-3, p_order=2, last_iterate=True, delta=0.4, memory=20, B0=0.4, qn='broyd', half=1)\n",
    "gaps = []\n",
    "iters = 0\n",
    "while iters < 20000:\n",
    "    def closure():\n",
    "        optimizer.zero_grad()\n",
    "        return F_torch(param, A_torch, b_torch)\n",
    "    func_loss = gap_torch(param, A_torch, b_torch, R)\n",
    "    gaps.append(func_loss.item())\n",
    "\n",
    "    optimizer.step(closure)\n",
    "    iters += 1\n",
    "\n",
    "\n",
    "plt.plot(gaps)\n",
    "plt.title('VIQA')\n",
    "plt.yscale('log')\n",
    "plt.xlabel('iteration')\n",
    "plt.ylabel('Gap')\n",
    "plt.show()\n",
    "broyd = gaps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "6d99b699",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "n = 50\n",
    "A = np.eye(n)\n",
    "for i in range(n - 1):\n",
    "    A[i, i + 1] = -1\n",
    "b = np.zeros(n)\n",
    "b[0] = 1  # NOTE: was in the original paper\n",
    "A_torch = torch.tensor(A)\n",
    "b_torch = torch.tensor(b)\n",
    "x = torch.zeros_like(b_torch, requires_grad=True)\n",
    "y = torch.zeros_like(b_torch, requires_grad=True)\n",
    "param = [x,y]\n",
    "optimizer = VIQA(param, L=.1e-3, p_order=2, last_iterate=True, delta=0.22, memory=20, qn='Broyd_damped', B0=0.22)\n",
    "gaps = []\n",
    "iters = 0\n",
    "while iters < 20000:\n",
    "    def closure():\n",
    "        optimizer.zero_grad()\n",
    "        return F_torch(param, A_torch, b_torch)\n",
    "    func_loss = gap_torch(param, A_torch, b_torch, R)\n",
    "    gaps.append(func_loss.item())\n",
    "\n",
    "    optimizer.step(closure)\n",
    "    iters += 1\n",
    "\n",
    "plt.plot(gaps)\n",
    "plt.title('VIQA')\n",
    "plt.yscale('log')\n",
    "plt.xlabel('iteration')\n",
    "plt.ylabel('Gap')\n",
    "plt.show()\n",
    "\n",
    "VIQA2 = gaps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "18a71f27",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "N = 20000\n",
    "step = 500\n",
    "plt.tight_layout()\n",
    "plt.semilogy(range(0,len(EG1[:N]),step), EG1[:N:step], 'b-', label='EG', )\n",
    "plt.semilogy(range(0,len(PERSEUS1[:N]),step), PERSEUS1[:N:step], 'm:', label='Perseus1')\n",
    "plt.semilogy(range(0,len(PERSEUS2[:N])), PERSEUS2[:N], 'g--', label='Perseus2')\n",
    "plt.semilogy(range(0,len(VIQA2[:N]),step), VIQA2[:N:step], 'r-.', label='VIQA Damped Broyd')\n",
    "plt.semilogy(range(0,len(broyd[:N]),step), broyd[:N:step], linestyle='dashed', label='VIQA Broyd')\n",
    "plt.legend()\n",
    "plt.xlabel('Iteration, k')\n",
    "plt.ylabel('Gap')\n",
    "plt.axis([-1000, 20000, 1e-14, 2.,], emit=True)\n",
    "plt.minorticks_on()\n",
    "plt.savefig('GAP_iter.pdf', format='pdf')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 800x600 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.pyplot import figure\n",
    "\n",
    "figure(figsize=(8, 6))\n",
    "plt.tight_layout()\n",
    "\n",
    "N = 20000\n",
    "step = 500\n",
    "plt.semilogy(2*np.array(range(0,len(EG1[:N]),step)), EG1[:N:step], 'b-', label='EG', )\n",
    "\n",
    "plt.semilogy(2*np.array(range(0,len(PERSEUS1[:N]),step)), PERSEUS1[:N:step], 'm:', label='Perseus1')\n",
    "plt.semilogy((n+1)*np.array(range(0,len(PERSEUS2[:N]))), PERSEUS2[:N], 'g--', label='Perseus2')\n",
    "plt.semilogy(2*np.array(range(0,len(VIQA2[:N]),step)), VIQA2[:N:step], 'r-.', label='VIQA Damped Broyd')\n",
    "plt.semilogy(2*np.array(range(0,len(broyd[:N]),step)), broyd[:N:step], linestyle='dashed', label='VIQA Broyd')\n",
    "\n",
    "plt.legend()\n",
    "plt.xlabel('JVP/F(x) computations')\n",
    "plt.ylabel('Gap')\n",
    "\n",
    "plt.axis([-1000, 40000, 1e-14, 2.,], emit=True)\n",
    "plt.minorticks_on()\n",
    "# plt.xticks(rotation=-70)\n",
    "plt.savefig('GAP_jvp.pdf', format='pdf')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "outputs": [],
   "source": [],
   "metadata": {
    "collapsed": false
   }
  }
 ],
 "metadata": {
  "kernelspec": {
   "name": "pycharm-a2b5a0e2",
   "language": "python",
   "display_name": "PyCharm (Optami)"
  },
  "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
