{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b677a86b-802b-49c1-a8bd-73ae655eb687",
   "metadata": {},
   "source": [
    "## Example 2a: Nonconvex Minimax Problems without Constraints.\n",
    "We consider the following possibly nonconvex-nonconcave minimax problem:\n",
    "\\begin{equation}\n",
    "\\min_{u \\in \\mathbb{R}^{p_1}}\\max_{v\\in\\mathbb{R}^{p_2}}\\Big\\{ \\mathcal{L}(u,v) = f(u) + \\frac{1}{n}\\sum_{i=1}^n\\big[u^{\\top}A_iu + u^{\\top}L_iv - v^{\\top}B_iv + b_i^{\\top}u - c_i^{\\top}v\\big] - g(v) \\Big\\},\n",
    "\\end{equation}\n",
    "where $A_i \\in\\mathbb{R}^{p_1\\times p_1}$ and $B_i \\in \\mathbb{R}^{p_2\\times p_2}$ are symmetric matrices, $b_i \\in\\mathbb{R}^{p_1}$, $c_i \\in\\mathbb{R}^{p_2}$, and $L_i \\in \\mathbb{R}^{p_1\\times p_2}$ is a given matrix.\n",
    "Here, we add two terms $f(u)$ and $g(v)$ to possibly handle constraints or regularizers associated with $u$ and $v$, respectively.\n",
    "\n",
    "In this experiment, we consider the case $f = 0$ and $g=0$, without constraints. The optimality condition of the minimax problem reduces to $G(x) = 0$ as a linear equation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "32cb27db-072b-4b4c-a74f-c3190fb29a8a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from   numpy import linalg as la\n",
    "import matplotlib.pyplot as plt\n",
    "import random\n",
    "import scipy as sci\n",
    "import solvers.ne_solvers as solver"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e13801fe-7f6b-48d6-8aba-bc627bec58db",
   "metadata": {},
   "source": [
    "## Evaluate The Operator $G(x)$\n",
    "Define the perator $G(x) := [Au + Lv + b, -L^{\\top}u + Bv + c]$ for our experiments, where $A := \\frac{1}{n}\\sum_{i=1}^nA_i$, $B := \\frac{1}{n}\\sum_{i=1}^nB_i$, $L := \\frac{1}{n}\\sum_{i=1}^nL_i$, $b := \\frac{1}{n}\\sum_{i=1}^nb_i$, and $c := \\frac{1}{n}\\sum_{i=1}^nc_i$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "2730b330-8391-410d-a607-ccb231edd706",
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"\n",
    "-- Define the operator G for our methods\n",
    "-- Inputs: data, x=x(k), mb_id=the indices of minibatch-size, mb_size=the size of mini-batch.\n",
    "-- Output: G(x).\n",
    "\"\"\"\n",
    "def G_op_eval(data, x, mb_id, mb_size):\n",
    "    \n",
    "    K = data.get(\"K\")\n",
    "    b = data.get(\"b\")\n",
    "    \n",
    "    return np.mean([K[i].dot(x) + b[i] for i in mb_id], axis=0)\n",
    "    \n",
    "\"\"\"\n",
    "-- Define the operator G and also output the output components.\n",
    "\"\"\"\n",
    "def Gb_op_eval(data, x, mb_id, mb_size):\n",
    "    \n",
    "    K   = data.get(\"K\")\n",
    "    b   = data.get(\"b\")\n",
    "    y_b = [K[i].dot(x) + b[i] for i in mb_id]\n",
    "    \n",
    "    return np.mean(y_b, axis=0), np.array(y_b).T"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5f8c15bc-ec12-49d1-a35a-5247033128ec",
   "metadata": {},
   "source": [
    "## Generate Input Data for The Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "8f66ce84-58ff-4d5c-b3e9-ba2b7dd612e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_data(n, p):\n",
    "    \n",
    "    # generate a symmetric matrix.\n",
    "    LB_D  = 0.0\n",
    "    p1    = int(p/2)\n",
    "    p2    = p-p1\n",
    "    K, b  = [], []\n",
    "    K_sum = []\n",
    "    \n",
    "    for i in range(n):\n",
    "        # Generate KKT matrix\n",
    "        D1  = np.maximum(np.diag(np.random.randn(p1)), -LB_D)\n",
    "        #D1  = D1/np.sum(D1, axis=1, keepdims=True)\n",
    "        Q1, _ = la.qr(np.random.randn(p1, p1))\n",
    "        Ai = np.matmul(np.matmul(Q1, D1), Q1.T)\n",
    "        \n",
    "        D2  = np.maximum(np.diag(np.random.randn(p2)), -LB_D)\n",
    "        #D2  = D2/np.sum(D2, axis=1, keepdims=True)\n",
    "        Q2, _ = la.qr(np.random.randn(p2, p2))\n",
    "        Bi = np.matmul(np.matmul(Q2, D2), Q2.T)\n",
    "        \n",
    "        Li = np.random.randn(p1,p2)\n",
    "        #Li = Li/np.sum(Li, axis=1, keepdims=True)\n",
    "        \n",
    "        Ki = np.block([[Ai,  Li], [-Li, Bi]])\n",
    "        ##Ki = Ki/np.sum(Ki, axis=1, keepdims=True)\n",
    "        ##Ki = Ki/la.norm(Ki, ord=2)\n",
    "    \n",
    "        # generate bi.\n",
    "        bi = np.random.randn(p)\n",
    "        #bi = bi/np.sum(bi)\n",
    "        \n",
    "        K.append(Ki)\n",
    "        b.append(bi)\n",
    "        if i==0:\n",
    "            K_sum = Ki\n",
    "        else:\n",
    "            K_sum = K_sum + Ki\n",
    "            \n",
    "    K_sum = (1/n)*K_sum\n",
    "    Lips = la.norm(K_sum, ord=2)    \n",
    "    my_data = dict({\"K\": K, \"b\": b, \"n\": n, \"p\": p, \"L\": Lips})\n",
    "    print(\"The Lipschitz constant:\", Lips)\n",
    "    \n",
    "    ## general an initial point.\n",
    "    x0 = np.random.randn(p)\n",
    "    \n",
    "    # return results.\n",
    "    return my_data, x0"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "414cc4bb-3fc3-4cc9-b290-2800be77ddfe",
   "metadata": {},
   "source": [
    "## Prepare to Run All Algorithm at Once"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "0ea44591-5aea-4f34-8b2d-4544f4bebe6d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def OneRun(my_data, x0):\n",
    "    \n",
    "    ## check the problem size.\n",
    "    print(\"Problem size: n = \", my_data.get('n'), \", p = \", my_data.get('p'))\n",
    "\n",
    "    ## Extract information from the data.\n",
    "    Lips = my_data.get(\"L\")\n",
    "    n    = my_data.get(\"n\")\n",
    "    p    = my_data.get(\"p\")\n",
    "\n",
    "    ## Save all the outputs.\n",
    "    all_outputs      = []\n",
    "    \n",
    "    ## set default parameters\n",
    "    my_is_term       = False ## using termination condition or not.\n",
    "    my_verbose       = 1\n",
    "    def_max_iters    = 10000\n",
    "    def_tol          = 1e-20\n",
    "    def_n_max_epochs = 50\n",
    "    def_gamma        = 0.75\n",
    "    def_mb_size      = int(n**0.67)\n",
    "    \n",
    "    ## Perform experiments with different mini-batch and probability.\n",
    "    my_mb_size_all   = max(int(0.1*n),5)\n",
    "    my_prob_all      = 1.0/(n**(1/3))\n",
    "    my_lr_all        = 2.0/(np.sqrt(my_mb_size_all)*Lips)\n",
    "\n",
    "    ## Optimistic gradient method\n",
    "    my_max_iters = def_n_max_epochs\n",
    "    og_lr        = 1.0/Lips\n",
    "    print('The learning rate of OG: ', og_lr)\n",
    "    output1      = solver.OGA(my_data, G_op_eval, x0, gamma=0.5, eta=og_lr,\\\n",
    "                              verbose=my_verbose, n_max_iters=my_max_iters, \\\n",
    "                              tol=def_tol, is_term = my_is_term)\n",
    "    print(\"Solver status (OG):     \", output1[\"message\"])\n",
    "    all_outputs.append(output1)\n",
    "    \n",
    "    ## Double-loop SVRG-Forward Reflected method\n",
    "    my_mb_size2     = my_mb_size_all\n",
    "    my_lr2          = my_lr_all\n",
    "    my_inner_iters2 = int(n/my_mb_size2)\n",
    "    print('The learning rate of VR-FR: ', my_lr2)\n",
    "    output2         = solver.Vr_FRA(my_data, G_op_eval, x0, mb_size=my_mb_size2, gamma=def_gamma, \\\n",
    "                                    eta=my_lr2, verbose=my_verbose, n_epochs=def_n_max_epochs, \\\n",
    "                                    n_inner_iters=my_inner_iters2, tol=def_tol, is_term = my_is_term)\n",
    "    print(\"Solver status (VR-FR):  \", output2[\"message\"])\n",
    "    all_outputs.append(output2)\n",
    "    \n",
    "    ## Loopless SVRG-Forward Reflected method\n",
    "    my_mb_size3 = my_mb_size_all\n",
    "    my_prob3    = my_prob_all\n",
    "    my_lr3      = my_lr_all\n",
    "    print('The learning rate of LVR-FR: ', my_lr3)\n",
    "    output3     = solver.LVr_FRA(my_data, G_op_eval, x0, mb_size=my_mb_size3, prob=my_prob3, gamma=def_gamma, \\\n",
    "                                 eta=my_lr3, verbose=my_verbose, n_epochs=def_n_max_epochs, tol=def_tol, \\\n",
    "                                 is_term = my_is_term)\n",
    "    print(\"Solver status (LVR-FR): \", output3[\"message\"])\n",
    "    all_outputs.append(output3)\n",
    "\n",
    "    ## The Saga-Forward-Reflected Method.\n",
    "    my_gamma6   = 0.75\n",
    "    my_mb_size6 = my_mb_size_all\n",
    "    my_lr6      = my_lr_all\n",
    "    print('The learning rate of SAGA-FR: ', my_lr6)\n",
    "    output6     = solver.Saga_FRA(my_data, G_op_eval, Gb_op_eval, x0, mb_size=my_mb_size6, eta=my_lr6, \\\n",
    "                                  gamma=my_gamma6,  verbose=my_verbose, n_epochs=def_n_max_epochs, \\\n",
    "                                  tol=def_tol, is_term = my_is_term)\n",
    "    print(\"Solver status (SAGA-FR):\", output6.get(\"message\"))\n",
    "    all_outputs.append(output6)\n",
    "    \n",
    "    ## SVRG Forward-Reflected-Backward Splitting Method\n",
    "    my_prob4    = my_prob_all\n",
    "    my_mb_size4 = my_mb_size_all\n",
    "    # Theoretical learning rate\n",
    "    my_lr4      = 0.95*(1 - np.sqrt(1-my_prob4))/(2.0*Lips)\n",
    "    print('The learning rate of VR-FRBS: ', my_lr4)\n",
    "    output4     = solver.Vr_FRBSA(my_data, G_op_eval, x0, mb_size=my_mb_size4, prob=my_prob4, eta=my_lr4, \\\n",
    "                                  verbose=my_verbose, n_epochs=def_n_max_epochs, tol=def_tol, is_term = my_is_term)\n",
    "    print(\"Solver status (VR-FRBS):\", output4[\"message\"])\n",
    "    all_outputs.append(output4)\n",
    "    \n",
    "    ## SVRG Extragradient method\n",
    "    my_prob5    = my_prob_all\n",
    "    my_mb_size5 = my_mb_size_all\n",
    "    my_alpha5   = 1 - my_prob5 \n",
    "    my_lr5      = 0.95*np.sqrt(1-my_alpha5)/Lips\n",
    "    print('The learning rate of VR-EG: ', my_lr5)\n",
    "    output5     = solver.Vr_EGA(my_data, G_op_eval, x0, mb_size=my_mb_size5, prob=my_prob5, eta=my_lr5, \\\n",
    "                                alpha=my_alpha5, verbose=my_verbose, n_epochs=def_n_max_epochs, \\\n",
    "                                tol=def_tol, is_term = my_is_term)\n",
    "    print(\"Solver status (VR-EG):  \", output5[\"message\"])\n",
    "    all_outputs.append(output5)\n",
    "    \n",
    "    # return outputs\n",
    "    return all_outputs\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f671cea9-1d0c-4000-94d4-42685c449792",
   "metadata": {},
   "source": [
    "## Run Experiment 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1cc1c888-b026-43ff-859c-789724da28c8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "************************ We are running Experiment 1 ... ************************\n",
      "=======> We are running time  0  of Experiment 1\n",
      "The Lipschitz constant: 0.5385139751090776\n",
      "Problem size: n =  5000 , p =  100\n",
      "The learning rate of OG:  1.8569620218257976\n",
      "Solver: Optimistic Gradient Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   0     |   3.620e+00   |   1.000e+00   |\n",
      "   20    |   9.055e-03   |   3.506e-03   |\n",
      "   40    |   6.885e-05   |   2.606e-05   |\n",
      "========================================== \n",
      "\n",
      "Solver status (OG):      Exceed the maximum number of epochs. Increase it to run further ...\n",
      "The learning rate of VR-FR:  0.5252281752155612\n",
      "Solver: SVRG-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   0     |   9.973e+00   |   1.000e+00   |\n",
      "   1     |   4.802e+00   |   4.214e-01   |\n",
      "   2     |   2.389e+00   |   2.123e-01   |\n",
      "   3     |   1.137e+00   |   1.112e-01   |\n",
      "   4     |   5.204e-01   |   4.925e-02   |\n",
      "   5     |   2.377e-01   |   2.541e-02   |\n",
      "   6     |   1.191e-01   |   1.022e-02   |\n",
      "   7     |   5.096e-02   |   5.501e-03   |\n",
      "   8     |   2.467e-02   |   2.222e-03   |\n",
      "   9     |   1.284e-02   |   1.219e-03   |\n",
      "   10    |   6.221e-03   |   5.849e-04   |\n",
      "   11    |   2.841e-03   |   2.704e-04   |\n",
      "   12    |   1.354e-03   |   1.309e-04   |\n",
      "   13    |   7.107e-04   |   6.226e-05   |\n",
      "   14    |   3.166e-04   |   2.744e-05   |\n",
      "   15    |   1.478e-04   |   1.571e-05   |\n",
      "   16    |   6.296e-05   |   6.690e-06   |\n",
      "   17    |   2.995e-05   |   2.822e-06   |\n",
      "   18    |   1.236e-05   |   1.214e-06   |\n",
      "   19    |   5.765e-06   |   5.548e-07   |\n",
      "   20    |   2.566e-06   |   2.497e-07   |\n",
      "   21    |   1.237e-06   |   1.111e-07   |\n",
      "   22    |   6.113e-07   |   5.411e-08   |\n",
      "   23    |   2.604e-07   |   2.458e-08   |\n",
      "   24    |   1.157e-07   |   1.088e-08   |\n",
      "   25    |   6.198e-08   |   5.417e-09   |\n",
      "   26    |   3.215e-08   |   2.917e-09   |\n",
      "   27    |   1.450e-08   |   1.332e-09   |\n",
      "   28    |   7.932e-09   |   7.480e-10   |\n",
      "   29    |   3.680e-09   |   3.499e-10   |\n",
      "   30    |   1.836e-09   |   1.692e-10   |\n",
      "   31    |   9.705e-10   |   8.130e-11   |\n",
      "   32    |   5.316e-10   |   4.979e-11   |\n",
      "   33    |   2.418e-10   |   2.371e-11   |\n",
      "   34    |   1.227e-10   |   1.156e-11   |\n",
      "   35    |   5.309e-11   |   5.344e-12   |\n",
      "   36    |   2.431e-11   |   2.717e-12   |\n",
      "   37    |   1.252e-11   |   1.089e-12   |\n",
      "   38    |   5.584e-12   |   5.381e-13   |\n",
      "   39    |   2.405e-12   |   2.297e-13   |\n",
      "   40    |   1.111e-12   |   1.067e-13   |\n",
      "   41    |   5.854e-13   |   5.198e-14   |\n",
      "   42    |   2.447e-13   |   2.198e-14   |\n",
      "   43    |   1.387e-13   |   1.198e-14   |\n",
      "   44    |   7.521e-14   |   6.507e-15   |\n",
      "   45    |   3.327e-14   |   3.097e-15   |\n",
      "   46    |   1.653e-14   |   1.571e-15   |\n",
      "   47    |   8.256e-15   |   7.540e-16   |\n",
      "   48    |   3.868e-15   |   3.954e-16   |\n",
      "   49    |   2.272e-15   |   1.979e-16   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-FR):   Exceed the maximum number of epochs. Increase it to run further ...\n",
      "The learning rate of LVR-FR:  0.5252281752155612\n",
      "Solver: Loopless-SVRG-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   5.120e-01   |   2.500e-01   |\n",
      "   2     |   1.629e-02   |   7.955e-03   |\n",
      "   3     |   5.372e-04   |   2.623e-04   |\n",
      "   4     |   1.369e-04   |   6.685e-05   |\n",
      "   5     |   2.493e-06   |   1.217e-06   |\n",
      "   6     |   2.881e-08   |   1.407e-08   |\n",
      "   7     |   9.207e-09   |   4.496e-09   |\n",
      "   8     |   6.675e-11   |   3.260e-11   |\n",
      "   9     |   1.876e-11   |   9.159e-12   |\n",
      "   10    |   3.031e-12   |   1.480e-12   |\n",
      "   11    |   3.474e-13   |   1.696e-13   |\n",
      "   12    |   2.075e-14   |   1.013e-14   |\n",
      "   13    |   4.951e-16   |   2.414e-16   |\n",
      "   14    |   2.280e-16   |   1.111e-16   |\n",
      "   15    |   3.094e-16   |   1.505e-16   |\n",
      "   16    |   2.664e-16   |   1.303e-16   |\n",
      "   17    |   2.810e-16   |   1.383e-16   |\n",
      "   18    |   2.830e-16   |   1.391e-16   |\n",
      "   19    |   2.682e-16   |   1.310e-16   |\n",
      "   20    |   2.660e-16   |   1.310e-16   |\n",
      "   21    |   2.572e-16   |   1.256e-16   |\n",
      "   22    |   2.401e-16   |   1.196e-16   |\n",
      "   23    |   3.101e-16   |   1.517e-16   |\n",
      "   24    |   2.967e-16   |   1.460e-16   |\n",
      "   25    |   2.756e-16   |   1.342e-16   |\n",
      "   26    |   3.072e-16   |   1.488e-16   |\n",
      "   27    |   2.699e-16   |   1.322e-16   |\n",
      "   28    |   2.257e-16   |   1.115e-16   |\n",
      "   29    |   3.207e-16   |   1.571e-16   |\n",
      "   30    |   2.406e-16   |   1.190e-16   |\n",
      "   31    |   3.573e-16   |   1.735e-16   |\n",
      "   32    |   2.777e-16   |   1.370e-16   |\n",
      "   33    |   2.827e-16   |   1.381e-16   |\n",
      "   34    |   2.732e-16   |   1.330e-16   |\n",
      "   35    |   2.497e-16   |   1.214e-16   |\n",
      "   36    |   2.845e-16   |   1.389e-16   |\n",
      "   37    |   2.379e-16   |   1.176e-16   |\n",
      "   38    |   3.001e-16   |   1.454e-16   |\n",
      "   39    |   2.621e-16   |   1.277e-16   |\n",
      "   40    |   3.962e-16   |   1.950e-16   |\n",
      "   41    |   2.764e-16   |   1.365e-16   |\n",
      "   42    |   3.351e-16   |   1.635e-16   |\n",
      "   43    |   3.332e-16   |   1.634e-16   |\n",
      "   44    |   2.526e-16   |   1.251e-16   |\n",
      "   45    |   2.255e-16   |   1.114e-16   |\n",
      "   46    |   2.703e-16   |   1.341e-16   |\n",
      "   47    |   2.603e-16   |   1.276e-16   |\n",
      "   48    |   2.651e-16   |   1.304e-16   |\n",
      "   49    |   2.318e-16   |   1.140e-16   |\n",
      "   50    |   2.352e-16   |   1.150e-16   |\n",
      "========================================== \n",
      "\n",
      "Solver status (LVR-FR):  Exceed the maximum number of epochs. Increase it to run further ...\n",
      "The learning rate of SAGA-FR:  0.5252281752155612\n",
      "Solver: SAGA-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Iters  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   5.120e-01   |   2.500e-01   |\n",
      "   2     |   1.047e+00   |   5.112e-01   |\n",
      "   3     |   7.393e-01   |   3.610e-01   |\n",
      "   4     |   4.919e-01   |   2.402e-01   |\n",
      "   5     |   2.875e-01   |   1.404e-01   |\n",
      "   6     |   2.118e-01   |   1.034e-01   |\n",
      "   7     |   1.296e-01   |   6.327e-02   |\n",
      "   8     |   1.004e-01   |   4.903e-02   |\n",
      "   9     |   7.307e-02   |   3.568e-02   |\n",
      "   10    |   4.841e-02   |   2.364e-02   |\n",
      "   11    |   3.284e-02   |   1.604e-02   |\n",
      "   12    |   1.801e-02   |   8.796e-03   |\n",
      "   13    |   1.570e-02   |   7.668e-03   |\n",
      "   14    |   2.812e-02   |   1.373e-02   |\n",
      "   15    |   8.354e-03   |   4.079e-03   |\n",
      "   16    |   4.725e-03   |   2.307e-03   |\n",
      "   17    |   3.814e-03   |   1.862e-03   |\n",
      "   18    |   2.740e-03   |   1.338e-03   |\n",
      "   19    |   1.362e-03   |   6.651e-04   |\n",
      "   20    |   1.066e-03   |   5.204e-04   |\n",
      "   21    |   8.032e-04   |   3.922e-04   |\n",
      "   22    |   4.344e-04   |   2.121e-04   |\n",
      "   23    |   3.647e-04   |   1.781e-04   |\n",
      "   24    |   2.364e-04   |   1.154e-04   |\n",
      "   25    |   1.675e-04   |   8.177e-05   |\n",
      "   26    |   1.230e-04   |   6.008e-05   |\n",
      "   27    |   1.016e-04   |   4.960e-05   |\n",
      "   28    |   5.589e-05   |   2.729e-05   |\n",
      "   29    |   4.261e-05   |   2.081e-05   |\n",
      "   30    |   3.128e-05   |   1.527e-05   |\n",
      "   31    |   2.185e-05   |   1.067e-05   |\n",
      "   32    |   1.313e-05   |   6.413e-06   |\n",
      "   33    |   8.312e-06   |   4.059e-06   |\n",
      "   34    |   7.052e-06   |   3.444e-06   |\n",
      "   35    |   4.277e-06   |   2.089e-06   |\n",
      "   36    |   3.285e-06   |   1.604e-06   |\n",
      "   37    |   1.869e-06   |   9.127e-07   |\n",
      "   38    |   9.970e-06   |   4.868e-06   |\n",
      "   39    |   2.344e-06   |   1.145e-06   |\n",
      "   40    |   1.312e-06   |   6.409e-07   |\n",
      "   41    |   7.549e-07   |   3.686e-07   |\n",
      "   42    |   7.248e-07   |   3.539e-07   |\n",
      "   43    |   4.470e-07   |   2.183e-07   |\n",
      "   44    |   3.228e-07   |   1.576e-07   |\n",
      "   45    |   2.317e-07   |   1.132e-07   |\n",
      "   46    |   1.605e-07   |   7.838e-08   |\n",
      "   47    |   8.731e-08   |   4.264e-08   |\n",
      "   48    |   7.962e-08   |   3.888e-08   |\n",
      "   49    |   4.684e-08   |   2.287e-08   |\n",
      "   50    |   3.468e-08   |   1.694e-08   |\n",
      "========================================== \n",
      "\n",
      "Solver status (SAGA-FR): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "The learning rate of VR-FRBS:  0.026180021988418914\n",
      "Solver: Variance-Reduced Forward-Reflected-Backward Splitting (Alacaoglu et al 2021) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   1.021e-01   |   1.000e+00   |\n",
      "   2     |   7.646e-02   |   7.490e-01   |\n",
      "   3     |   1.677e-02   |   1.643e-01   |\n",
      "   4     |   8.174e-03   |   8.007e-02   |\n",
      "   5     |   5.431e-03   |   5.321e-02   |\n",
      "   6     |   1.625e-03   |   1.592e-02   |\n",
      "   7     |   1.999e-03   |   1.958e-02   |\n",
      "   8     |   3.940e-04   |   3.860e-03   |\n",
      "   9     |   3.182e-04   |   3.117e-03   |\n",
      "   10    |   2.310e-04   |   2.263e-03   |\n",
      "   11    |   4.659e-05   |   4.565e-04   |\n",
      "   12    |   4.127e-05   |   4.043e-04   |\n",
      "   13    |   1.773e-05   |   1.737e-04   |\n",
      "   14    |   2.261e-05   |   2.215e-04   |\n",
      "   15    |   3.325e-06   |   3.258e-05   |\n",
      "   16    |   1.897e-06   |   1.858e-05   |\n",
      "   17    |   7.366e-07   |   7.216e-06   |\n",
      "   18    |   3.751e-07   |   3.674e-06   |\n",
      "   19    |   1.834e-07   |   1.796e-06   |\n",
      "   20    |   1.311e-07   |   1.285e-06   |\n",
      "   21    |   5.250e-08   |   5.144e-07   |\n",
      "   22    |   2.742e-08   |   2.686e-07   |\n",
      "   23    |   1.150e-08   |   1.126e-07   |\n",
      "   24    |   8.571e-09   |   8.396e-08   |\n",
      "   25    |   5.087e-09   |   4.983e-08   |\n",
      "   26    |   1.748e-09   |   1.712e-08   |\n",
      "   27    |   8.493e-10   |   8.320e-09   |\n",
      "   28    |   4.518e-10   |   4.426e-09   |\n",
      "   29    |   2.503e-10   |   2.452e-09   |\n",
      "   30    |   1.387e-10   |   1.359e-09   |\n",
      "   31    |   6.736e-11   |   6.599e-10   |\n",
      "   32    |   3.309e-11   |   3.241e-10   |\n",
      "   33    |   1.707e-11   |   1.673e-10   |\n",
      "   34    |   1.416e-11   |   1.388e-10   |\n",
      "   35    |   4.401e-12   |   4.311e-11   |\n",
      "   36    |   2.731e-12   |   2.675e-11   |\n",
      "   37    |   1.463e-12   |   1.433e-11   |\n",
      "   38    |   1.450e-12   |   1.421e-11   |\n",
      "   39    |   7.715e-13   |   7.558e-12   |\n",
      "   40    |   2.009e-13   |   1.968e-12   |\n",
      "   41    |   8.953e-14   |   8.771e-13   |\n",
      "   42    |   4.886e-14   |   4.786e-13   |\n",
      "   43    |   2.035e-14   |   1.994e-13   |\n",
      "   44    |   1.572e-14   |   1.540e-13   |\n",
      "   45    |   5.391e-15   |   5.283e-14   |\n",
      "   46    |   6.947e-15   |   6.802e-14   |\n",
      "   47    |   3.719e-15   |   3.641e-14   |\n",
      "   48    |   8.929e-16   |   8.740e-15   |\n",
      "   49    |   4.319e-16   |   4.232e-15   |\n",
      "   50    |   2.016e-16   |   1.976e-15   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-FRBS): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "The learning rate of VR-EG:  0.42661058441436395\n",
      "Solver: Variance-Reduced Extragradient Method (Alacaoglu & Malitsky 2022) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   1.500e+00   |   9.018e-01   |\n",
      "   2     |   1.498e-01   |   1.019e-01   |\n",
      "   3     |   3.766e-02   |   3.022e-02   |\n",
      "   4     |   1.581e-02   |   1.158e-02   |\n",
      "   5     |   7.178e-03   |   4.915e-03   |\n",
      "   6     |   4.163e-03   |   3.279e-03   |\n",
      "   7     |   6.444e-04   |   4.919e-04   |\n",
      "   8     |   2.449e-04   |   1.702e-04   |\n",
      "   9     |   4.895e-05   |   3.638e-05   |\n",
      "   10    |   9.592e-06   |   7.535e-06   |\n",
      "   11    |   3.080e-06   |   2.291e-06   |\n",
      "   12    |   1.376e-06   |   9.513e-07   |\n",
      "   13    |   2.889e-07   |   1.949e-07   |\n",
      "   14    |   3.147e-08   |   2.513e-08   |\n",
      "   15    |   2.667e-08   |   1.978e-08   |\n",
      "   16    |   6.924e-09   |   5.515e-09   |\n",
      "   17    |   3.536e-09   |   2.610e-09   |\n",
      "   18    |   1.933e-09   |   1.467e-09   |\n",
      "   19    |   3.977e-10   |   2.724e-10   |\n",
      "   20    |   4.276e-11   |   3.085e-11   |\n",
      "   21    |   2.801e-11   |   1.892e-11   |\n",
      "   22    |   8.608e-12   |   6.046e-12   |\n",
      "   23    |   2.241e-12   |   1.584e-12   |\n",
      "   24    |   8.845e-13   |   6.989e-13   |\n",
      "   25    |   1.690e-13   |   1.181e-13   |\n",
      "   26    |   6.311e-14   |   4.767e-14   |\n",
      "   27    |   2.579e-14   |   1.693e-14   |\n",
      "   28    |   5.872e-15   |   4.385e-15   |\n",
      "   29    |   3.179e-15   |   2.296e-15   |\n",
      "   30    |   1.253e-15   |   9.496e-16   |\n",
      "   31    |   4.180e-16   |   2.783e-16   |\n",
      "   32    |   2.318e-16   |   1.244e-16   |\n",
      "   33    |   2.253e-16   |   1.189e-16   |\n",
      "   34    |   2.247e-16   |   1.196e-16   |\n",
      "   35    |   2.010e-16   |   1.013e-16   |\n",
      "   36    |   2.058e-16   |   1.174e-16   |\n",
      "   37    |   2.159e-16   |   1.100e-16   |\n",
      "   38    |   2.158e-16   |   9.557e-17   |\n",
      "   39    |   2.194e-16   |   1.180e-16   |\n",
      "   40    |   2.232e-16   |   1.109e-16   |\n",
      "   41    |   1.892e-16   |   9.803e-17   |\n",
      "   42    |   2.215e-16   |   1.039e-16   |\n",
      "   43    |   2.499e-16   |   1.293e-16   |\n",
      "   44    |   2.544e-16   |   1.264e-16   |\n",
      "   45    |   1.566e-16   |   8.308e-17   |\n",
      "   46    |   1.864e-16   |   1.028e-16   |\n",
      "   47    |   2.214e-16   |   1.127e-16   |\n",
      "   48    |   2.152e-16   |   1.113e-16   |\n",
      "   49    |   2.017e-16   |   1.171e-16   |\n",
      "   50    |   2.175e-16   |   1.197e-16   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-EG):   Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Finished!\n"
     ]
    }
   ],
   "source": [
    "## Experiment 1\n",
    "print(\"************************ We are running Experiment 1 ... ************************\")\n",
    "n1, p1 = 5000, 100\n",
    "n_num_of_runs = 1\n",
    "experiment1 = []\n",
    "for n_run in range(n_num_of_runs):\n",
    "    print(\"=======> We are running time \", n_run, \" of Experiment 1\")\n",
    "    my_data1, x01 = generate_data(n1, p1)\n",
    "    output1 = OneRun(my_data1, x01)\n",
    "    experiment1.append(output1)\n",
    "print(\"Finished!\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0c5d1c68-f0d2-4970-b6eb-5478cb078b8f",
   "metadata": {},
   "source": [
    "## Run Experiment 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "beecba3c-7e5a-42fa-a3e5-902ebac56e8e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "************************ We are running Experiment 2 ... ************************\n",
      "=======> We are running time  0  of Experiment 2\n",
      "The Lipschitz constant: 0.5420483631305496\n",
      "Problem size: n =  10000 , p =  200\n",
      "The learning rate of OG:  1.8448538322753962\n",
      "Solver: Optimistic Gradient Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   0     |   5.805e+00   |   1.000e+00   |\n",
      "   20    |   1.384e-02   |   3.355e-03   |\n",
      "   40    |   1.038e-04   |   2.447e-05   |\n",
      "========================================== \n",
      "\n",
      "Solver status (OG):      Exceed the maximum number of epochs. Increase it to run further ...\n",
      "The learning rate of VR-FR:  0.36897076645507926\n",
      "Solver: SVRG-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   0     |   1.539e+01   |   1.000e+00   |\n",
      "   1     |   4.568e+00   |   2.920e-01   |\n",
      "   2     |   1.573e+00   |   9.797e-02   |\n",
      "   3     |   5.889e-01   |   3.307e-02   |\n",
      "   4     |   2.066e-01   |   1.276e-02   |\n",
      "   5     |   7.136e-02   |   4.333e-03   |\n",
      "   6     |   2.349e-02   |   1.463e-03   |\n",
      "   7     |   8.284e-03   |   5.049e-04   |\n",
      "   8     |   2.982e-03   |   1.894e-04   |\n",
      "   9     |   1.056e-03   |   6.395e-05   |\n",
      "   10    |   3.729e-04   |   2.391e-05   |\n",
      "   11    |   1.372e-04   |   8.410e-06   |\n",
      "   12    |   5.039e-05   |   3.159e-06   |\n",
      "   13    |   1.687e-05   |   1.056e-06   |\n",
      "   14    |   6.429e-06   |   3.967e-07   |\n",
      "   15    |   2.262e-06   |   1.359e-07   |\n",
      "   16    |   7.806e-07   |   4.802e-08   |\n",
      "   17    |   2.642e-07   |   1.580e-08   |\n",
      "   18    |   9.289e-08   |   5.694e-09   |\n",
      "   19    |   3.267e-08   |   2.043e-09   |\n",
      "   20    |   1.117e-08   |   6.734e-10   |\n",
      "   21    |   4.127e-09   |   2.514e-10   |\n",
      "   22    |   1.354e-09   |   8.213e-11   |\n",
      "   23    |   4.630e-10   |   2.867e-11   |\n",
      "   24    |   1.709e-10   |   1.046e-11   |\n",
      "   25    |   5.672e-11   |   3.461e-12   |\n",
      "   26    |   2.061e-11   |   1.271e-12   |\n",
      "   27    |   7.686e-12   |   4.877e-13   |\n",
      "   28    |   2.805e-12   |   1.701e-13   |\n",
      "   29    |   9.756e-13   |   5.995e-14   |\n",
      "   30    |   3.456e-13   |   2.130e-14   |\n",
      "   31    |   1.301e-13   |   7.816e-15   |\n",
      "   32    |   4.892e-14   |   3.224e-15   |\n",
      "   33    |   1.640e-14   |   1.060e-15   |\n",
      "   34    |   6.432e-15   |   3.671e-16   |\n",
      "   35    |   2.918e-15   |   1.692e-16   |\n",
      "   36    |   1.894e-15   |   1.054e-16   |\n",
      "   37    |   1.458e-15   |   7.653e-17   |\n",
      "   38    |   1.289e-15   |   6.537e-17   |\n",
      "   39    |   1.289e-15   |   6.649e-17   |\n",
      "   40    |   1.318e-15   |   7.113e-17   |\n",
      "   41    |   1.419e-15   |   6.806e-17   |\n",
      "   42    |   1.438e-15   |   7.060e-17   |\n",
      "   43    |   1.388e-15   |   6.947e-17   |\n",
      "   44    |   1.374e-15   |   6.596e-17   |\n",
      "   45    |   1.406e-15   |   7.044e-17   |\n",
      "   46    |   1.339e-15   |   7.042e-17   |\n",
      "   47    |   1.296e-15   |   7.147e-17   |\n",
      "   48    |   1.425e-15   |   6.999e-17   |\n",
      "   49    |   1.401e-15   |   6.679e-17   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-FR):   Exceed the maximum number of epochs. Increase it to run further ...\n",
      "The learning rate of LVR-FR:  0.36897076645507926\n",
      "Solver: Loopless-SVRG-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   5.805e-01   |   2.500e-01   |\n",
      "   2     |   2.939e-01   |   1.266e-01   |\n",
      "   3     |   8.419e-03   |   3.626e-03   |\n",
      "   4     |   1.225e-03   |   5.277e-04   |\n",
      "   5     |   9.284e-05   |   3.998e-05   |\n",
      "   6     |   3.254e-05   |   1.401e-05   |\n",
      "   7     |   7.719e-06   |   3.324e-06   |\n",
      "   8     |   1.843e-07   |   7.937e-08   |\n",
      "   9     |   2.039e-07   |   8.781e-08   |\n",
      "   10    |   4.326e-09   |   1.863e-09   |\n",
      "   11    |   4.316e-10   |   1.859e-10   |\n",
      "   12    |   8.482e-12   |   3.653e-12   |\n",
      "   13    |   7.825e-13   |   3.370e-13   |\n",
      "   14    |   8.948e-14   |   3.853e-14   |\n",
      "   15    |   1.257e-14   |   5.413e-15   |\n",
      "   16    |   9.336e-15   |   4.021e-15   |\n",
      "   17    |   2.173e-16   |   9.367e-17   |\n",
      "   18    |   1.611e-16   |   6.973e-17   |\n",
      "   19    |   1.845e-16   |   7.962e-17   |\n",
      "   20    |   2.082e-16   |   8.867e-17   |\n",
      "   21    |   1.934e-16   |   8.415e-17   |\n",
      "   22    |   1.979e-16   |   8.550e-17   |\n",
      "   23    |   1.875e-16   |   8.089e-17   |\n",
      "   24    |   2.288e-16   |   9.902e-17   |\n",
      "   25    |   1.932e-16   |   8.308e-17   |\n",
      "   26    |   1.940e-16   |   8.435e-17   |\n",
      "   27    |   2.023e-16   |   8.744e-17   |\n",
      "   28    |   2.229e-16   |   9.609e-17   |\n",
      "   29    |   2.085e-16   |   9.017e-17   |\n",
      "   30    |   1.634e-16   |   7.043e-17   |\n",
      "   31    |   2.025e-16   |   8.672e-17   |\n",
      "   32    |   1.967e-16   |   8.524e-17   |\n",
      "   33    |   2.206e-16   |   9.562e-17   |\n",
      "   34    |   2.057e-16   |   8.894e-17   |\n",
      "   35    |   1.968e-16   |   8.444e-17   |\n",
      "   36    |   2.041e-16   |   8.831e-17   |\n",
      "   37    |   2.003e-16   |   8.627e-17   |\n",
      "   38    |   1.935e-16   |   8.431e-17   |\n",
      "   39    |   2.094e-16   |   9.005e-17   |\n",
      "   40    |   2.151e-16   |   9.301e-17   |\n",
      "   41    |   1.952e-16   |   8.454e-17   |\n",
      "   42    |   1.996e-16   |   8.484e-17   |\n",
      "   43    |   2.438e-16   |   1.055e-16   |\n",
      "   44    |   2.058e-16   |   8.914e-17   |\n",
      "   45    |   2.201e-16   |   9.437e-17   |\n",
      "   46    |   1.906e-16   |   8.275e-17   |\n",
      "   47    |   2.002e-16   |   8.646e-17   |\n",
      "   48    |   1.958e-16   |   8.556e-17   |\n",
      "   49    |   1.928e-16   |   8.376e-17   |\n",
      "   50    |   1.820e-16   |   7.885e-17   |\n",
      "========================================== \n",
      "\n",
      "Solver status (LVR-FR):  Exceed the maximum number of epochs. Increase it to run further ...\n",
      "The learning rate of SAGA-FR:  0.36897076645507926\n",
      "Solver: SAGA-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Iters  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   5.805e-01   |   2.500e-01   |\n",
      "   2     |   9.382e-01   |   4.040e-01   |\n",
      "   3     |   6.409e-01   |   2.760e-01   |\n",
      "   4     |   4.084e-01   |   1.759e-01   |\n",
      "   5     |   2.723e-01   |   1.173e-01   |\n",
      "   6     |   1.438e-01   |   6.195e-02   |\n",
      "   7     |   1.124e-01   |   4.840e-02   |\n",
      "   8     |   8.311e-02   |   3.579e-02   |\n",
      "   9     |   6.210e-02   |   2.674e-02   |\n",
      "   10    |   2.876e-02   |   1.238e-02   |\n",
      "   11    |   4.413e-02   |   1.900e-02   |\n",
      "   12    |   1.781e-02   |   7.671e-03   |\n",
      "   13    |   9.966e-03   |   4.292e-03   |\n",
      "   14    |   7.078e-03   |   3.048e-03   |\n",
      "   15    |   3.479e-03   |   1.498e-03   |\n",
      "   16    |   1.930e-03   |   8.310e-04   |\n",
      "   17    |   1.148e-03   |   4.942e-04   |\n",
      "   18    |   7.169e-04   |   3.087e-04   |\n",
      "   19    |   4.801e-04   |   2.068e-04   |\n",
      "   20    |   4.539e-04   |   1.955e-04   |\n",
      "   21    |   2.153e-04   |   9.271e-05   |\n",
      "   22    |   1.041e-04   |   4.485e-05   |\n",
      "   23    |   8.801e-05   |   3.790e-05   |\n",
      "   24    |   4.602e-05   |   1.982e-05   |\n",
      "   25    |   3.514e-05   |   1.513e-05   |\n",
      "   26    |   1.731e-05   |   7.455e-06   |\n",
      "   27    |   1.297e-05   |   5.587e-06   |\n",
      "   28    |   1.028e-05   |   4.429e-06   |\n",
      "   29    |   5.541e-06   |   2.386e-06   |\n",
      "   30    |   4.007e-06   |   1.726e-06   |\n",
      "   31    |   4.571e-06   |   1.968e-06   |\n",
      "   32    |   2.108e-06   |   9.076e-07   |\n",
      "   33    |   1.196e-06   |   5.150e-07   |\n",
      "   34    |   7.801e-07   |   3.360e-07   |\n",
      "   35    |   4.722e-07   |   2.033e-07   |\n",
      "   36    |   2.540e-07   |   1.094e-07   |\n",
      "   37    |   1.773e-07   |   7.636e-08   |\n",
      "   38    |   1.508e-07   |   6.494e-08   |\n",
      "   39    |   7.629e-08   |   3.285e-08   |\n",
      "   40    |   5.610e-08   |   2.416e-08   |\n",
      "   41    |   2.950e-08   |   1.270e-08   |\n",
      "   42    |   2.108e-08   |   9.080e-09   |\n",
      "   43    |   1.292e-08   |   5.566e-09   |\n",
      "   44    |   1.024e-08   |   4.412e-09   |\n",
      "   45    |   1.167e-08   |   5.026e-09   |\n",
      "   46    |   5.122e-09   |   2.206e-09   |\n",
      "   47    |   4.051e-09   |   1.745e-09   |\n",
      "   48    |   1.619e-09   |   6.970e-10   |\n",
      "   49    |   1.370e-09   |   5.901e-10   |\n",
      "   50    |   6.907e-10   |   2.975e-10   |\n",
      "========================================== \n",
      "\n",
      "Solver status (SAGA-FR): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "The learning rate of VR-FRBS:  0.020578884783827273\n",
      "Solver: Variance-Reduced Forward-Reflected-Backward Splitting (Alacaoglu et al 2021) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   1.295e-01   |   1.000e+00   |\n",
      "   2     |   6.398e-02   |   4.940e-01   |\n",
      "   3     |   3.909e-02   |   3.018e-01   |\n",
      "   4     |   2.302e-02   |   1.777e-01   |\n",
      "   5     |   2.669e-02   |   2.061e-01   |\n",
      "   6     |   9.666e-03   |   7.464e-02   |\n",
      "   7     |   6.069e-03   |   4.686e-02   |\n",
      "   8     |   1.695e-03   |   1.308e-02   |\n",
      "   9     |   1.030e-03   |   7.950e-03   |\n",
      "   10    |   4.763e-04   |   3.678e-03   |\n",
      "   11    |   5.261e-04   |   4.062e-03   |\n",
      "   12    |   3.412e-04   |   2.635e-03   |\n",
      "   13    |   1.071e-04   |   8.273e-04   |\n",
      "   14    |   4.898e-05   |   3.782e-04   |\n",
      "   15    |   2.724e-05   |   2.103e-04   |\n",
      "   16    |   2.047e-05   |   1.580e-04   |\n",
      "   17    |   9.299e-06   |   7.180e-05   |\n",
      "   18    |   1.350e-05   |   1.042e-04   |\n",
      "   19    |   2.911e-06   |   2.248e-05   |\n",
      "   20    |   1.512e-06   |   1.167e-05   |\n",
      "   21    |   1.086e-06   |   8.385e-06   |\n",
      "   22    |   7.955e-07   |   6.142e-06   |\n",
      "   23    |   3.048e-07   |   2.353e-06   |\n",
      "   24    |   1.679e-07   |   1.296e-06   |\n",
      "   25    |   1.371e-07   |   1.059e-06   |\n",
      "   26    |   5.489e-08   |   4.238e-07   |\n",
      "   27    |   4.959e-08   |   3.829e-07   |\n",
      "   28    |   2.138e-08   |   1.651e-07   |\n",
      "   29    |   1.594e-08   |   1.231e-07   |\n",
      "   30    |   7.960e-09   |   6.146e-08   |\n",
      "   31    |   4.781e-09   |   3.692e-08   |\n",
      "   32    |   1.851e-09   |   1.429e-08   |\n",
      "   33    |   1.396e-09   |   1.078e-08   |\n",
      "   34    |   7.694e-10   |   5.941e-09   |\n",
      "   35    |   4.718e-10   |   3.643e-09   |\n",
      "   36    |   2.780e-10   |   2.147e-09   |\n",
      "   37    |   1.845e-10   |   1.424e-09   |\n",
      "   38    |   7.723e-11   |   5.963e-10   |\n",
      "   39    |   4.961e-11   |   3.831e-10   |\n",
      "   40    |   3.561e-11   |   2.749e-10   |\n",
      "   41    |   1.566e-11   |   1.209e-10   |\n",
      "   42    |   7.485e-12   |   5.780e-11   |\n",
      "   43    |   5.238e-12   |   4.044e-11   |\n",
      "   44    |   2.778e-12   |   2.145e-11   |\n",
      "   45    |   1.519e-12   |   1.173e-11   |\n",
      "   46    |   2.073e-12   |   1.601e-11   |\n",
      "   47    |   5.204e-13   |   4.019e-12   |\n",
      "   48    |   3.840e-13   |   2.965e-12   |\n",
      "   49    |   1.717e-13   |   1.326e-12   |\n",
      "   50    |   1.886e-13   |   1.456e-12   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-FRBS): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "The learning rate of VR-EG:  0.37758862395777554\n",
      "Solver: Variance-Reduced Extragradient Method (Alacaoglu & Malitsky 2022) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   2.143e+00   |   9.020e-01   |\n",
      "   2     |   5.028e-01   |   3.036e-01   |\n",
      "   3     |   2.559e-01   |   1.521e-01   |\n",
      "   4     |   4.795e-02   |   2.536e-02   |\n",
      "   5     |   1.965e-02   |   1.036e-02   |\n",
      "   6     |   7.238e-03   |   3.612e-03   |\n",
      "   7     |   1.719e-03   |   9.070e-04   |\n",
      "   8     |   5.648e-04   |   3.057e-04   |\n",
      "   9     |   1.344e-04   |   8.004e-05   |\n",
      "   10    |   1.023e-04   |   5.202e-05   |\n",
      "   11    |   4.374e-05   |   2.693e-05   |\n",
      "   12    |   2.711e-05   |   1.141e-05   |\n",
      "   13    |   2.007e-05   |   9.802e-06   |\n",
      "   14    |   5.754e-06   |   3.187e-06   |\n",
      "   15    |   1.834e-06   |   1.052e-06   |\n",
      "   16    |   2.390e-07   |   1.311e-07   |\n",
      "   17    |   5.282e-08   |   3.158e-08   |\n",
      "   18    |   1.053e-08   |   5.952e-09   |\n",
      "   19    |   3.482e-09   |   2.075e-09   |\n",
      "   20    |   1.804e-09   |   9.644e-10   |\n",
      "   21    |   7.624e-10   |   4.372e-10   |\n",
      "   22    |   1.645e-10   |   8.358e-11   |\n",
      "   23    |   1.319e-10   |   7.104e-11   |\n",
      "   24    |   2.931e-11   |   1.762e-11   |\n",
      "   25    |   1.196e-11   |   6.710e-12   |\n",
      "   26    |   9.771e-12   |   5.356e-12   |\n",
      "   27    |   6.004e-12   |   3.438e-12   |\n",
      "   28    |   2.930e-12   |   1.478e-12   |\n",
      "   29    |   2.509e-12   |   1.313e-12   |\n",
      "   30    |   1.398e-12   |   6.639e-13   |\n",
      "   31    |   5.635e-13   |   2.961e-13   |\n",
      "   32    |   1.793e-13   |   1.063e-13   |\n",
      "   33    |   6.654e-14   |   3.629e-14   |\n",
      "   34    |   8.588e-15   |   4.848e-15   |\n",
      "   35    |   2.761e-15   |   1.546e-15   |\n",
      "   36    |   5.639e-16   |   3.178e-16   |\n",
      "   37    |   3.610e-16   |   1.566e-16   |\n",
      "   38    |   2.932e-16   |   1.218e-16   |\n",
      "   39    |   2.579e-16   |   9.028e-17   |\n",
      "   40    |   2.115e-16   |   7.914e-17   |\n",
      "   41    |   2.473e-16   |   9.354e-17   |\n",
      "   42    |   2.449e-16   |   9.355e-17   |\n",
      "   43    |   2.136e-16   |   7.942e-17   |\n",
      "   44    |   2.047e-16   |   7.539e-17   |\n",
      "   45    |   2.382e-16   |   8.412e-17   |\n",
      "   46    |   2.011e-16   |   7.476e-17   |\n",
      "   47    |   2.309e-16   |   7.940e-17   |\n",
      "   48    |   2.271e-16   |   8.211e-17   |\n",
      "   49    |   2.228e-16   |   7.390e-17   |\n",
      "   50    |   2.404e-16   |   9.225e-17   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-EG):   Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Finished!\n"
     ]
    }
   ],
   "source": [
    "## Experiment 2\n",
    "print(\"************************ We are running Experiment 2 ... ************************\")\n",
    "n2, p2 = 10000, 200\n",
    "n_num_of_runs = 1\n",
    "experiment2 = []\n",
    "for n_run in range(n_num_of_runs):\n",
    "    print(\"=======> We are running time \", n_run, \" of Experiment 2\")\n",
    "    my_data2, x0_2 = generate_data(n2, p2)\n",
    "    output2 = OneRun(my_data2, x0_2)\n",
    "    experiment2.append(output2)\n",
    "print(\"Finished!\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0f6fc923-0e47-4543-b7e9-f84b64b09287",
   "metadata": {},
   "source": [
    "## Plot The Results of The Experiments\n",
    "This section plots the results of our experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "af9689b8-36e6-474b-af3f-8ee532413290",
   "metadata": {},
   "outputs": [],
   "source": [
    "## For Exmperiment 1.\n",
    "n_algs = len(experiment1[0])\n",
    "iter_all1, op_norm_all1 = [], []\n",
    "for k in range(n_algs):\n",
    "    iter_run, op_norm_run = [], []\n",
    "    for i in range(n_num_of_runs):\n",
    "        output_all1 = experiment1[i]\n",
    "        output_tmp1 = output_all1[k]\n",
    "        iter_run.append( [h.get(\"epoch\") for h in output_tmp1.get(\"epoch_hist\")] )\n",
    "        op_norm_run.append( [h.get(\"op_norm\") for h in output_tmp1.get(\"epoch_hist\")] )\n",
    "    iter_all1.append(iter_run)\n",
    "    op_norm_all1.append(op_norm_run)\n",
    "\n",
    "## Compute the mean value of the iterate.\n",
    "avg_iter1, avg_norm_un1 = [], []\n",
    "for k in range(n_algs):\n",
    "    avg_iter1.append( np.mean(iter_all1[k], axis=0) )\n",
    "    avg_norm_un1.append( np.array(op_norm_all1[k]) )\n",
    "\n",
    "## Compute the mean value of the norm.\n",
    "avg_norm_n1 = []\n",
    "for k in range(n_algs):\n",
    "    avg_norm_n1.append( np.mean(avg_norm_un1[k], axis=0)  )\n",
    "\n",
    "## Normalize\n",
    "avg_norm_f1 = []\n",
    "for k in range(n_algs):\n",
    "    tmp = avg_norm_n1[k]\n",
    "    avg_norm_f1.append( tmp / np.maximum(1, tmp[0]) )\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "9ddd28fc-3fd8-4b13-bb99-9cdfff6e2f2d",
   "metadata": {},
   "outputs": [],
   "source": [
    "## For Exmperiment 2.\n",
    "n_algs = len(experiment2[0])\n",
    "iter_all2, op_norm_all2 = [], []\n",
    "for k in range(n_algs):\n",
    "    iter_run, op_norm_run = [], []\n",
    "    for i in range(n_num_of_runs):\n",
    "        output_all2 = experiment2[i]\n",
    "        output_tmp2 = output_all2[k]\n",
    "        iter_run.append( [h.get(\"epoch\") for h in output_tmp2.get(\"epoch_hist\")] )\n",
    "        op_norm_run.append( [h.get(\"op_norm\") for h in output_tmp2.get(\"epoch_hist\")] )\n",
    "    iter_all2.append(iter_run)\n",
    "    op_norm_all2.append(op_norm_run)\n",
    "\n",
    "## Compute the mean value of the iterate.\n",
    "avg_iter2, avg_norm_un2 = [], []\n",
    "for k in range(n_algs):\n",
    "    avg_iter2.append( np.mean(iter_all2[k], axis=0) )\n",
    "    avg_norm_un2.append( np.array(op_norm_all2[k]) )\n",
    "\n",
    "## Compute the mean value of the norm.\n",
    "avg_norm_n2 = []\n",
    "for k in range(n_algs):\n",
    "    avg_norm_n2.append( np.mean(avg_norm_un2[k], axis=0)  )\n",
    "\n",
    "## Normalize\n",
    "avg_norm_f2 = []\n",
    "for k in range(n_algs):\n",
    "    tmp = avg_norm_n2[k]\n",
    "    avg_norm_f2.append( tmp / np.maximum(1, tmp[0]) )\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "3caa7a4f-d46f-44e5-9f83-bdf187c5d466",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1200x350 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "## Now we plot the results.\n",
    "p_e1, n_e1  = p1, n1\n",
    "p_e2, n_e2  = p2, n2\n",
    "\n",
    "fig, axs = plt.subplots(1, 2, figsize=(12, 3.5))\n",
    "plt.rc('text', usetex=True)\n",
    "alg_names     = ['OG','VFR-svrg', 'LVFR-svrg', 'VFR-saga', 'VFRBS', 'VEG'] \n",
    "l_colors      = ['b', 'r', 'g', 'm', 'y', 'k']\n",
    "l_line_styles = ['-.', '--', '-', '-.', '--', '-']\n",
    "l_markers  = ['o', '*', 'd', 's', '>', 'x']\n",
    "\n",
    "for k in range(n_algs):\n",
    "    axs[0].semilogy(avg_iter1[k], avg_norm_f1[k], marker= l_markers[k], linewidth=2, linestyle=l_line_styles[k], color=l_colors[k], \\\n",
    "                    markersize=4, markevery=5, label=alg_names[k]);   \n",
    "axs[0].set_title(\"Experiment 1: n = \" + str(n_e1) + \" and p = \" + str(p_e1), fontsize=11)\n",
    "axs[0].legend()\n",
    "axs[0].grid(True)\n",
    "axs[0].set_xlabel('Number of epochs')\n",
    "axs[0].set_ylabel('Relative operator norm $\\Vert Gx^k \\Vert/\\Vert Gx^0\\Vert$')\n",
    "\n",
    "for k in range(n_algs):\n",
    "    axs[1].semilogy(avg_iter2[k], avg_norm_f2[k], marker= l_markers[k], linewidth=2, linestyle=l_line_styles[k], color=l_colors[k], \\\n",
    "                    markersize=4, markevery=5, label=alg_names[k]);   \n",
    "axs[1].set_title(\"Experiment 2: n = \" + str(n_e2) + \" and p = \" + str(p_e2), fontsize=11)\n",
    "axs[1].legend()\n",
    "axs[1].grid(True)\n",
    "axs[1].set_xlabel('Number of epochs')\n",
    "axs[1].set_ylabel('Relative operator norm $\\Vert Gx^k\\Vert/\\Vert Gx^0\\Vert$')\n",
    "\n",
    "plt.show()\n",
    "fig.savefig(\"figs/unconstr_minimax_exam2_mb001.pdf\", format=\"pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4e0d224-e550-43d4-8a7e-ccca8f075722",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "41cfa19e-6950-401d-acdf-7efa7060c4b1",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
