{
 "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": 1,
   "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": 2,
   "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",
    "    K = data.get(\"K\")\n",
    "    b = data.get(\"b\")\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 in a submatrix.\n",
    "\"\"\"\n",
    "def Gb_op_eval(data, x, mb_id, mb_size):\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",
    "    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": 3,
   "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 # If LB_D > 0, then the problem is possibly nonconvex-nonconcave.\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 = 0.5*np.random.randn(p)\n",
    "    \n",
    "    # return results.\n",
    "    return my_data, x0"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "146f7e08-75ae-4e5e-9f45-4a5f32fff0aa",
   "metadata": {},
   "source": [
    "## Estimate The Theoretical Learning Rates"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "382f0ae0-eec3-420c-bcb5-29c3f4e52e5f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def ComputeStepSize(gam, p, b, n, method=\"SVRG\"):\n",
    "    if method==\"SVRG\":\n",
    "        Lambda = ( 4.0*(1 + gam**2)*(2-3*p) + 2*(3+2*gam**2)*p**2 ) / (b*p**2)\n",
    "        M = gam*(1 + 5*gam)/(3*(2*gam-1)) + (1+6*gam)/(3*(2*gam-1))*Lambda\n",
    "    else:\n",
    "        Lambda = 2/b + 4*(1+gam**2)*(n-b)*(2*n+b) / b**3\n",
    "        M = gam*(1 + 5*gam)/(3*(2*gam-1)) + (1+6*gam)/(3*(2*gam-1))*Lambda\n",
    "    return 1/np.sqrt(M)        "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "414cc4bb-3fc3-4cc9-b290-2800be77ddfe",
   "metadata": {},
   "source": [
    "## Prepare to Run All Algorithms at Once\n",
    "We package all algorithms in one procedure to run"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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",
    "    ## Save the outputs.\n",
    "    all_outputs  = []\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",
    "    ## set default parameters\n",
    "    my_verbose       = 0\n",
    "    my_is_term       = False  ## using termination condition or not.\n",
    "    def_max_iters    = 10000\n",
    "    def_tol          = 1e-20\n",
    "    def_n_max_epochs = 50\n",
    "    def_gamma        = 0.75\n",
    "    def_prob         = (1/n**(1/3))\n",
    "    def_mb_size      = int(n**(2/3))\n",
    "    \n",
    "    ## Other settings.\n",
    "    def_prob         = 1/n**(1/3)\n",
    "    def_mb_size      = int(0.5*n**(2/3))\n",
    "    ## End of other settings.\n",
    "    \n",
    "    def_mn_batch     = def_mb_size\n",
    "    #my_lr_all        = 2.0/(np.sqrt(def_mb_size)*Lips)\n",
    "\n",
    "    ## Compute the theoretical learning rates.\n",
    "    sig_svrg         = ComputeStepSize(def_gamma, def_prob, def_mn_batch, n, method=\"SVRG\")\n",
    "    sig_saga         = ComputeStepSize(def_gamma, def_prob, def_mn_batch, n, method=\"SAGA\")\n",
    "    \n",
    "    ### Other settings\n",
    "    sig_svrg         = 0.5\n",
    "    sig_saga         = 0.5\n",
    "    ### End of other settings\n",
    "    \n",
    "    print(\"Sigma-SVRG: \", sig_svrg, \", Sigma-SAGA: \", sig_saga)\n",
    "    print(\"Probability: \", def_prob, \", Mini-Batch Size: \", def_mn_batch)\n",
    "    print(\"++++++++++++++++++++ RUN ALL ALGORITHMS ++++++++++++++++++++\")\n",
    "    \n",
    "    ## Optimistic gradient method\n",
    "    my_max_iters = def_n_max_epochs\n",
    "    og_lr        = 1/Lips\n",
    "    print(\"Learning rate:\", 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     = def_mn_batch # default\n",
    "    my_inner_iters2 = int(n/my_mb_size2)\n",
    "    my_lr2          = sig_svrg/Lips\n",
    "    #my_lr2           = my_lr_all\n",
    "    print(\"Learning rate:\", my_lr2)\n",
    "    output2         = solver.Vr_FRA(my_data, G_op_eval, x0, mb_size=def_mb_size, \\\n",
    "                                    gamma=def_gamma, eta=my_lr2, verbose=my_verbose, \\\n",
    "                                    n_epochs=def_n_max_epochs, n_inner_iters=my_inner_iters2, \\\n",
    "                                    tol=def_tol, is_term = my_is_term)\n",
    "    print(\"Solver status (DVR-FR):\", output2[\"message\"])\n",
    "    all_outputs.append(output2)\n",
    "    \n",
    "    ## Loopless SVRG-Forward Reflected method\n",
    "    my_mb_size3 = def_mn_batch  # default value\n",
    "    my_prob3    = def_prob      # default value\n",
    "    my_lr3      = sig_svrg/Lips\n",
    "    #my_lr3      = my_lr_all\n",
    "    print(\"Learning rate:\", my_lr3)\n",
    "    output3     = solver.LVr_FRA(my_data, G_op_eval, x0, mb_size=my_mb_size3, prob=my_prob3, \\\n",
    "                                 gamma=def_gamma, eta=my_lr3, verbose=my_verbose, \\\n",
    "                                 n_epochs=def_n_max_epochs, tol=def_tol, is_term = my_is_term)\n",
    "    print(\"Solver status (LVR-FR):\", output3[\"message\"])\n",
    "    all_outputs.append(output3)\n",
    "    \n",
    "    ## The VR-FR-Saga method.\n",
    "    my_gamma6   = def_gamma\n",
    "    my_mb_size6 = def_mn_batch # default value\n",
    "    my_lr6      = sig_saga/Lips\n",
    "    #my_lr6      = my_lr_all\n",
    "    print(\"Learning rate:\", 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 (SGA-FR):\", output6.get(\"message\"))\n",
    "    all_outputs.append(output6)\n",
    "    \n",
    "    ## SVRG Forward-Reflected-Backward Splitting Method\n",
    "    my_prob4    = def_prob     # default value\n",
    "    my_mb_size4 = def_mn_batch # default value\n",
    "    # Theoretical learning rate\n",
    "    my_lr4      = 0.95*(1 - np.sqrt(1-my_prob4))/(2.0*Lips)\n",
    "    print(\"Learning rate:\", my_lr4)\n",
    "    output4     = solver.Vr_FRBSA(my_data, G_op_eval, x0, mb_size=my_mb_size4, prob=my_prob4, \\\n",
    "                                  eta=my_lr4, verbose=my_verbose, n_epochs=def_n_max_epochs, \\\n",
    "                                  tol=def_tol, is_term = my_is_term)\n",
    "    print(\"Solver status (VRFRBS):\", output4[\"message\"])\n",
    "    all_outputs.append(output4)\n",
    "    \n",
    "    ## SVRG Extragradient method\n",
    "    my_prob5    = np.minimum(def_prob, 0.99) # default value\n",
    "    my_mb_size5 = def_mn_batch # default value\n",
    "    my_alpha5   = 1 - my_prob5 \n",
    "    my_lr5      = 0.95*np.sqrt(1-my_alpha5)/Lips\n",
    "    print(\"Learning rate:\", my_lr5)\n",
    "    output5     = solver.Vr_EGA(my_data, G_op_eval, x0, mb_size=my_mb_size5, prob=my_prob5, \\\n",
    "                                eta=my_lr5, 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"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f671cea9-1d0c-4000-94d4-42685c449792",
   "metadata": {},
   "source": [
    "## Run Experiment 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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.5382927780697802\n",
      "Problem size: n =  5000 , p =  100\n",
      "Sigma-SVRG:  0.5 , Sigma-SAGA:  0.5\n",
      "Probability:  0.05848035476425732 , Mini-Batch Size:  146\n",
      "++++++++++++++++++++ RUN ALL ALGORITHMS ++++++++++++++++++++\n",
      "Learning rate: 1.8577250907690381\n",
      "Solver: Optimistic Gradient Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   0     |   1.924e+00   |   1.000e+00   |\n",
      "   20    |   5.089e-03   |   3.726e-03   |\n",
      "   40    |   3.550e-05   |   2.541e-05   |\n",
      "========================================== \n",
      "\n",
      "Solver status     (OG): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Learning rate: 0.9288625453845191\n",
      "Solver: SVRG-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   0     |   4.791e+00   |   1.000e+00   |\n",
      "   1     |   1.806e+00   |   3.428e-01   |\n",
      "   2     |   6.635e-01   |   1.297e-01   |\n",
      "   3     |   2.369e-01   |   4.839e-02   |\n",
      "   4     |   8.360e-02   |   1.650e-02   |\n",
      "   5     |   2.913e-02   |   5.546e-03   |\n",
      "   6     |   1.185e-02   |   2.108e-03   |\n",
      "   7     |   4.494e-03   |   8.238e-04   |\n",
      "   8     |   1.435e-03   |   2.854e-04   |\n",
      "   9     |   5.421e-04   |   1.037e-04   |\n",
      "   10    |   1.962e-04   |   3.764e-05   |\n",
      "   11    |   6.737e-05   |   1.273e-05   |\n",
      "   12    |   2.093e-05   |   4.154e-06   |\n",
      "   13    |   7.841e-06   |   1.572e-06   |\n",
      "   14    |   2.512e-06   |   4.963e-07   |\n",
      "   15    |   9.436e-07   |   1.801e-07   |\n",
      "   16    |   3.474e-07   |   6.775e-08   |\n",
      "   17    |   1.305e-07   |   2.440e-08   |\n",
      "   18    |   4.384e-08   |   8.836e-09   |\n",
      "   19    |   1.402e-08   |   2.709e-09   |\n",
      "   20    |   4.860e-09   |   1.000e-09   |\n",
      "   21    |   1.778e-09   |   3.480e-10   |\n",
      "   22    |   6.781e-10   |   1.252e-10   |\n",
      "   23    |   2.465e-10   |   4.793e-11   |\n",
      "   24    |   8.407e-11   |   1.695e-11   |\n",
      "   25    |   3.272e-11   |   6.144e-12   |\n",
      "   26    |   9.519e-12   |   1.950e-12   |\n",
      "   27    |   3.134e-12   |   6.286e-13   |\n",
      "   28    |   9.449e-13   |   1.878e-13   |\n",
      "   29    |   3.295e-13   |   6.880e-14   |\n",
      "   30    |   1.116e-13   |   2.283e-14   |\n",
      "   31    |   4.710e-14   |   8.721e-15   |\n",
      "   32    |   1.774e-14   |   3.177e-15   |\n",
      "   33    |   6.942e-15   |   1.303e-15   |\n",
      "   34    |   2.584e-15   |   4.790e-16   |\n",
      "   35    |   1.731e-15   |   2.691e-16   |\n",
      "   36    |   1.558e-15   |   2.208e-16   |\n",
      "   37    |   1.468e-15   |   2.406e-16   |\n",
      "   38    |   1.287e-15   |   1.992e-16   |\n",
      "   39    |   1.692e-15   |   1.901e-16   |\n",
      "   40    |   1.665e-15   |   2.424e-16   |\n",
      "   41    |   1.429e-15   |   2.070e-16   |\n",
      "   42    |   1.335e-15   |   2.040e-16   |\n",
      "   43    |   1.367e-15   |   2.115e-16   |\n",
      "   44    |   1.233e-15   |   1.730e-16   |\n",
      "   45    |   1.483e-15   |   2.006e-16   |\n",
      "   46    |   1.524e-15   |   2.309e-16   |\n",
      "   47    |   1.428e-15   |   2.089e-16   |\n",
      "   48    |   1.490e-15   |   2.098e-16   |\n",
      "   49    |   1.368e-15   |   2.108e-16   |\n",
      "========================================== \n",
      "\n",
      "Solver status (DVR-FR): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Learning rate: 0.9288625453845191\n",
      "Solver: Loopless-SVRG-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   4.811e-01   |   2.500e-01   |\n",
      "   2     |   5.024e-02   |   2.611e-02   |\n",
      "   3     |   6.797e-03   |   3.532e-03   |\n",
      "   4     |   3.336e-03   |   1.734e-03   |\n",
      "   5     |   2.423e-04   |   1.259e-04   |\n",
      "   6     |   2.264e-04   |   1.176e-04   |\n",
      "   7     |   2.201e-05   |   1.144e-05   |\n",
      "   8     |   2.649e-06   |   1.377e-06   |\n",
      "   9     |   3.493e-06   |   1.815e-06   |\n",
      "   10    |   5.751e-07   |   2.988e-07   |\n",
      "   11    |   3.685e-08   |   1.915e-08   |\n",
      "   12    |   1.463e-08   |   7.603e-09   |\n",
      "   13    |   1.353e-09   |   7.028e-10   |\n",
      "   14    |   1.022e-09   |   5.313e-10   |\n",
      "   15    |   3.200e-10   |   1.663e-10   |\n",
      "   16    |   4.366e-11   |   2.269e-11   |\n",
      "   17    |   6.496e-12   |   3.376e-12   |\n",
      "   18    |   7.289e-13   |   3.788e-13   |\n",
      "   19    |   4.169e-14   |   2.166e-14   |\n",
      "   20    |   2.644e-14   |   1.374e-14   |\n",
      "   21    |   1.441e-15   |   7.496e-16   |\n",
      "   22    |   4.623e-16   |   2.391e-16   |\n",
      "   23    |   6.960e-16   |   3.605e-16   |\n",
      "   24    |   4.568e-16   |   2.390e-16   |\n",
      "   25    |   4.562e-16   |   2.368e-16   |\n",
      "   26    |   5.635e-16   |   2.921e-16   |\n",
      "   27    |   3.282e-16   |   1.692e-16   |\n",
      "   28    |   4.023e-16   |   2.096e-16   |\n",
      "   29    |   4.418e-16   |   2.304e-16   |\n",
      "   30    |   5.080e-16   |   2.624e-16   |\n",
      "   31    |   3.634e-16   |   1.885e-16   |\n",
      "   32    |   3.964e-16   |   2.046e-16   |\n",
      "   33    |   4.689e-16   |   2.426e-16   |\n",
      "   34    |   4.991e-16   |   2.588e-16   |\n",
      "   35    |   5.889e-16   |   3.062e-16   |\n",
      "   36    |   5.836e-16   |   3.035e-16   |\n",
      "   37    |   3.972e-16   |   2.066e-16   |\n",
      "   38    |   4.856e-16   |   2.513e-16   |\n",
      "   39    |   4.138e-16   |   2.156e-16   |\n",
      "   40    |   5.172e-16   |   2.677e-16   |\n",
      "   41    |   4.393e-16   |   2.259e-16   |\n",
      "   42    |   4.367e-16   |   2.262e-16   |\n",
      "   43    |   5.564e-16   |   2.891e-16   |\n",
      "   44    |   3.935e-16   |   2.040e-16   |\n",
      "   45    |   4.310e-16   |   2.216e-16   |\n",
      "   46    |   4.603e-16   |   2.388e-16   |\n",
      "   47    |   4.207e-16   |   2.172e-16   |\n",
      "   48    |   4.827e-16   |   2.512e-16   |\n",
      "   49    |   4.648e-16   |   2.406e-16   |\n",
      "   50    |   4.704e-16   |   2.447e-16   |\n",
      "========================================== \n",
      "\n",
      "Solver status (LVR-FR): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Learning rate: 0.9288625453845191\n",
      "Solver: SAGA-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Iters  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   4.811e-01   |   2.500e-01   |\n",
      "   2     |   5.741e-01   |   2.983e-01   |\n",
      "   3     |   3.828e-01   |   1.989e-01   |\n",
      "   4     |   2.559e-01   |   1.330e-01   |\n",
      "   5     |   1.589e-01   |   8.255e-02   |\n",
      "   6     |   1.215e-01   |   6.313e-02   |\n",
      "   7     |   7.303e-02   |   3.795e-02   |\n",
      "   8     |   3.664e-02   |   1.904e-02   |\n",
      "   9     |   2.873e-02   |   1.493e-02   |\n",
      "   10    |   2.019e-02   |   1.049e-02   |\n",
      "   11    |   9.816e-03   |   5.101e-03   |\n",
      "   12    |   6.739e-03   |   3.502e-03   |\n",
      "   13    |   4.506e-03   |   2.341e-03   |\n",
      "   14    |   3.637e-03   |   1.890e-03   |\n",
      "   15    |   2.158e-03   |   1.122e-03   |\n",
      "   16    |   8.928e-04   |   4.639e-04   |\n",
      "   17    |   6.089e-04   |   3.164e-04   |\n",
      "   18    |   4.512e-04   |   2.345e-04   |\n",
      "   19    |   2.864e-04   |   1.488e-04   |\n",
      "   20    |   1.643e-04   |   8.538e-05   |\n",
      "   21    |   2.228e-04   |   1.158e-04   |\n",
      "   22    |   1.036e-04   |   5.381e-05   |\n",
      "   23    |   4.502e-05   |   2.339e-05   |\n",
      "   24    |   2.541e-05   |   1.320e-05   |\n",
      "   25    |   2.026e-05   |   1.053e-05   |\n",
      "   26    |   1.080e-05   |   5.613e-06   |\n",
      "   27    |   9.679e-06   |   5.029e-06   |\n",
      "   28    |   6.096e-06   |   3.167e-06   |\n",
      "   29    |   3.701e-06   |   1.923e-06   |\n",
      "   30    |   2.961e-06   |   1.538e-06   |\n",
      "   31    |   1.637e-06   |   8.506e-07   |\n",
      "   32    |   7.889e-07   |   4.100e-07   |\n",
      "   33    |   6.590e-07   |   3.424e-07   |\n",
      "   34    |   3.850e-07   |   2.001e-07   |\n",
      "   35    |   2.173e-07   |   1.129e-07   |\n",
      "   36    |   9.509e-08   |   4.941e-08   |\n",
      "   37    |   9.957e-08   |   5.174e-08   |\n",
      "   38    |   5.842e-08   |   3.036e-08   |\n",
      "   39    |   4.920e-08   |   2.557e-08   |\n",
      "   40    |   4.599e-08   |   2.390e-08   |\n",
      "   41    |   1.988e-08   |   1.033e-08   |\n",
      "   42    |   1.472e-08   |   7.649e-09   |\n",
      "   43    |   7.679e-09   |   3.990e-09   |\n",
      "   44    |   6.041e-09   |   3.139e-09   |\n",
      "   45    |   3.428e-09   |   1.781e-09   |\n",
      "   46    |   1.989e-09   |   1.034e-09   |\n",
      "   47    |   1.731e-09   |   8.996e-10   |\n",
      "   48    |   1.417e-09   |   7.361e-10   |\n",
      "   49    |   7.562e-10   |   3.930e-10   |\n",
      "   50    |   4.708e-10   |   2.447e-10   |\n",
      "========================================== \n",
      "\n",
      "Solver status (SGA-FR): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Learning rate: 0.026190779969184223\n",
      "Solver: Variance-Reduced Forward-Reflected-Backward Splitting (Alacaoglu et al 2021) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   5.426e-02   |   1.000e+00   |\n",
      "   2     |   3.874e-02   |   7.140e-01   |\n",
      "   3     |   2.872e-02   |   5.293e-01   |\n",
      "   4     |   2.076e-02   |   3.825e-01   |\n",
      "   5     |   1.522e-02   |   2.804e-01   |\n",
      "   6     |   1.185e-02   |   2.183e-01   |\n",
      "   7     |   8.831e-03   |   1.628e-01   |\n",
      "   8     |   7.488e-03   |   1.380e-01   |\n",
      "   9     |   4.966e-03   |   9.151e-02   |\n",
      "   10    |   3.253e-03   |   5.995e-02   |\n",
      "   11    |   2.708e-03   |   4.991e-02   |\n",
      "   12    |   2.259e-03   |   4.163e-02   |\n",
      "   13    |   1.492e-03   |   2.749e-02   |\n",
      "   14    |   1.144e-03   |   2.109e-02   |\n",
      "   15    |   8.720e-04   |   1.607e-02   |\n",
      "   16    |   7.043e-04   |   1.298e-02   |\n",
      "   17    |   4.987e-04   |   9.191e-03   |\n",
      "   18    |   6.746e-04   |   1.243e-02   |\n",
      "   19    |   2.926e-04   |   5.393e-03   |\n",
      "   20    |   2.214e-04   |   4.081e-03   |\n",
      "   21    |   1.947e-04   |   3.588e-03   |\n",
      "   22    |   1.410e-04   |   2.598e-03   |\n",
      "   23    |   1.557e-04   |   2.869e-03   |\n",
      "   24    |   1.041e-04   |   1.919e-03   |\n",
      "   25    |   7.192e-05   |   1.325e-03   |\n",
      "   26    |   4.963e-05   |   9.146e-04   |\n",
      "   27    |   4.545e-05   |   8.376e-04   |\n",
      "   28    |   3.902e-05   |   7.191e-04   |\n",
      "   29    |   4.880e-05   |   8.994e-04   |\n",
      "   30    |   2.354e-05   |   4.339e-04   |\n",
      "   31    |   1.776e-05   |   3.274e-04   |\n",
      "   32    |   1.519e-05   |   2.799e-04   |\n",
      "   33    |   1.190e-05   |   2.193e-04   |\n",
      "   34    |   8.603e-06   |   1.585e-04   |\n",
      "   35    |   7.574e-06   |   1.396e-04   |\n",
      "   36    |   6.266e-06   |   1.155e-04   |\n",
      "   37    |   3.898e-06   |   7.183e-05   |\n",
      "   38    |   3.053e-06   |   5.627e-05   |\n",
      "   39    |   2.604e-06   |   4.800e-05   |\n",
      "   40    |   1.863e-06   |   3.433e-05   |\n",
      "   41    |   1.562e-06   |   2.879e-05   |\n",
      "   42    |   1.377e-06   |   2.538e-05   |\n",
      "   43    |   8.923e-07   |   1.644e-05   |\n",
      "   44    |   7.170e-07   |   1.321e-05   |\n",
      "   45    |   5.682e-07   |   1.047e-05   |\n",
      "   46    |   4.539e-07   |   8.364e-06   |\n",
      "   47    |   3.371e-07   |   6.212e-06   |\n",
      "   48    |   2.608e-07   |   4.807e-06   |\n",
      "   49    |   2.102e-07   |   3.874e-06   |\n",
      "   50    |   1.519e-07   |   2.800e-06   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VRFRBS): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Learning rate: 0.42678588863922057\n",
      "Solver: Variance-Reduced Extragradient Method (Alacaoglu & Malitsky 2022) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   7.458e-01   |   8.435e-01   |\n",
      "   2     |   3.717e-01   |   6.164e-01   |\n",
      "   3     |   2.408e-01   |   2.723e-01   |\n",
      "   4     |   1.106e-01   |   2.213e-01   |\n",
      "   5     |   4.937e-02   |   9.424e-02   |\n",
      "   6     |   2.187e-02   |   4.003e-02   |\n",
      "   7     |   1.863e-02   |   3.240e-02   |\n",
      "   8     |   1.161e-02   |   2.416e-02   |\n",
      "   9     |   1.057e-02   |   1.774e-02   |\n",
      "   10    |   1.191e-02   |   2.025e-02   |\n",
      "   11    |   4.744e-03   |   9.476e-03   |\n",
      "   12    |   2.399e-03   |   4.248e-03   |\n",
      "   13    |   1.189e-03   |   2.156e-03   |\n",
      "   14    |   9.478e-04   |   1.688e-03   |\n",
      "   15    |   3.815e-04   |   7.112e-04   |\n",
      "   16    |   2.514e-04   |   4.415e-04   |\n",
      "   17    |   1.114e-04   |   2.018e-04   |\n",
      "   18    |   6.927e-05   |   1.471e-04   |\n",
      "   19    |   6.460e-05   |   1.266e-04   |\n",
      "   20    |   3.689e-05   |   6.853e-05   |\n",
      "   21    |   2.226e-05   |   4.050e-05   |\n",
      "   22    |   1.622e-05   |   3.925e-05   |\n",
      "   23    |   1.407e-05   |   2.613e-05   |\n",
      "   24    |   7.602e-06   |   1.555e-05   |\n",
      "   25    |   6.871e-06   |   1.263e-05   |\n",
      "   26    |   3.085e-06   |   6.450e-06   |\n",
      "   27    |   2.124e-06   |   4.109e-06   |\n",
      "   28    |   1.187e-06   |   2.543e-06   |\n",
      "   29    |   1.889e-06   |   2.136e-06   |\n",
      "   30    |   1.153e-06   |   1.304e-06   |\n",
      "   31    |   5.050e-07   |   1.015e-06   |\n",
      "   32    |   4.687e-07   |   8.064e-07   |\n",
      "   33    |   3.170e-07   |   5.943e-07   |\n",
      "   34    |   1.950e-07   |   3.773e-07   |\n",
      "   35    |   1.414e-07   |   2.457e-07   |\n",
      "   36    |   9.924e-08   |   1.930e-07   |\n",
      "   37    |   6.887e-08   |   1.287e-07   |\n",
      "   38    |   4.274e-08   |   7.451e-08   |\n",
      "   39    |   3.231e-08   |   6.579e-08   |\n",
      "   40    |   2.623e-08   |   5.143e-08   |\n",
      "   41    |   2.114e-08   |   4.135e-08   |\n",
      "   42    |   1.512e-08   |   2.657e-08   |\n",
      "   43    |   9.497e-09   |   1.856e-08   |\n",
      "   44    |   8.569e-09   |   1.404e-08   |\n",
      "   45    |   4.815e-09   |   9.349e-09   |\n",
      "   46    |   2.542e-09   |   5.875e-09   |\n",
      "   47    |   1.194e-09   |   2.135e-09   |\n",
      "   48    |   6.818e-10   |   1.486e-09   |\n",
      "   49    |   7.416e-10   |   1.505e-09   |\n",
      "   50    |   3.809e-10   |   7.989e-10   |\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 # Set this value to 10 to run 10 problem instances\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, x0_1 = generate_data(n1, p1)\n",
    "    output1 = OneRun(my_data1, x0_1)\n",
    "    experiment1.append(output1)\n",
    "print(\"Finished!\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0c5d1c68-f0d2-4970-b6eb-5478cb078b8f",
   "metadata": {},
   "source": [
    "## Run Experiment 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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.5395639490524216\n",
      "Problem size: n =  10000 , p =  200\n",
      "Sigma-SVRG:  0.5 , Sigma-SAGA:  0.5\n",
      "Probability:  0.0464158883361278 , Mini-Batch Size:  232\n",
      "++++++++++++++++++++ RUN ALL ALGORITHMS ++++++++++++++++++++\n",
      "Learning rate: 1.8533484339644875\n",
      "Solver: Optimistic Gradient Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   0     |   2.747e+00   |   1.000e+00   |\n",
      "   20    |   7.661e-03   |   3.907e-03   |\n",
      "   40    |   5.465e-05   |   2.744e-05   |\n",
      "========================================== \n",
      "\n",
      "Solver status     (OG): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Learning rate: 0.9266742169822437\n",
      "Solver: SVRG-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   0     |   7.956e+00   |   1.000e+00   |\n",
      "   1     |   3.507e+00   |   4.417e-01   |\n",
      "   2     |   1.481e+00   |   1.885e-01   |\n",
      "   3     |   6.229e-01   |   8.037e-02   |\n",
      "   4     |   2.306e-01   |   3.055e-02   |\n",
      "   5     |   1.034e-01   |   1.324e-02   |\n",
      "   6     |   4.273e-02   |   5.552e-03   |\n",
      "   7     |   1.834e-02   |   2.369e-03   |\n",
      "   8     |   6.769e-03   |   9.472e-04   |\n",
      "   9     |   2.968e-03   |   3.534e-04   |\n",
      "   10    |   1.293e-03   |   1.603e-04   |\n",
      "   11    |   4.941e-04   |   6.560e-05   |\n",
      "   12    |   1.939e-04   |   2.480e-05   |\n",
      "   13    |   7.186e-05   |   9.446e-06   |\n",
      "   14    |   2.919e-05   |   3.990e-06   |\n",
      "   15    |   1.059e-05   |   1.404e-06   |\n",
      "   16    |   4.494e-06   |   5.546e-07   |\n",
      "   17    |   1.927e-06   |   2.476e-07   |\n",
      "   18    |   8.412e-07   |   1.039e-07   |\n",
      "   19    |   3.464e-07   |   4.379e-08   |\n",
      "   20    |   1.365e-07   |   1.752e-08   |\n",
      "   21    |   5.422e-08   |   7.535e-09   |\n",
      "   22    |   2.374e-08   |   2.903e-09   |\n",
      "   23    |   9.785e-09   |   1.200e-09   |\n",
      "   24    |   3.726e-09   |   4.742e-10   |\n",
      "   25    |   1.690e-09   |   2.146e-10   |\n",
      "   26    |   7.047e-10   |   9.512e-11   |\n",
      "   27    |   3.008e-10   |   3.902e-11   |\n",
      "   28    |   1.298e-10   |   1.674e-11   |\n",
      "   29    |   5.902e-11   |   6.860e-12   |\n",
      "   30    |   2.351e-11   |   3.105e-12   |\n",
      "   31    |   9.666e-12   |   1.249e-12   |\n",
      "   32    |   3.906e-12   |   4.852e-13   |\n",
      "   33    |   1.634e-12   |   2.031e-13   |\n",
      "   34    |   6.340e-13   |   8.282e-14   |\n",
      "   35    |   2.606e-13   |   3.476e-14   |\n",
      "   36    |   1.063e-13   |   1.350e-14   |\n",
      "   37    |   4.933e-14   |   6.421e-15   |\n",
      "   38    |   2.153e-14   |   2.596e-15   |\n",
      "   39    |   8.926e-15   |   1.174e-15   |\n",
      "   40    |   4.411e-15   |   5.499e-16   |\n",
      "   41    |   2.675e-15   |   3.030e-16   |\n",
      "   42    |   2.436e-15   |   2.350e-16   |\n",
      "   43    |   2.364e-15   |   2.516e-16   |\n",
      "   44    |   2.359e-15   |   2.353e-16   |\n",
      "   45    |   2.736e-15   |   2.556e-16   |\n",
      "   46    |   2.380e-15   |   2.798e-16   |\n",
      "   47    |   2.461e-15   |   2.501e-16   |\n",
      "   48    |   2.186e-15   |   2.416e-16   |\n",
      "   49    |   2.422e-15   |   2.278e-16   |\n",
      "========================================== \n",
      "\n",
      "Solver status (DVR-FR): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Learning rate: 0.9266742169822437\n",
      "Solver: Loopless-SVRG-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   6.868e-01   |   2.500e-01   |\n",
      "   2     |   9.118e-02   |   3.319e-02   |\n",
      "   3     |   6.572e-02   |   2.392e-02   |\n",
      "   4     |   2.685e-02   |   9.774e-03   |\n",
      "   5     |   2.340e-03   |   8.517e-04   |\n",
      "   6     |   6.436e-04   |   2.343e-04   |\n",
      "   7     |   2.241e-04   |   8.158e-05   |\n",
      "   8     |   2.464e-04   |   8.970e-05   |\n",
      "   9     |   2.519e-04   |   9.171e-05   |\n",
      "   10    |   5.792e-05   |   2.109e-05   |\n",
      "   11    |   3.760e-05   |   1.369e-05   |\n",
      "   12    |   4.867e-06   |   1.772e-06   |\n",
      "   13    |   1.030e-06   |   3.748e-07   |\n",
      "   14    |   1.056e-07   |   3.844e-08   |\n",
      "   15    |   3.538e-08   |   1.288e-08   |\n",
      "   16    |   1.606e-09   |   5.847e-10   |\n",
      "   17    |   3.140e-09   |   1.143e-09   |\n",
      "   18    |   2.158e-10   |   7.855e-11   |\n",
      "   19    |   4.355e-10   |   1.585e-10   |\n",
      "   20    |   3.733e-11   |   1.359e-11   |\n",
      "   21    |   2.326e-11   |   8.468e-12   |\n",
      "   22    |   9.741e-12   |   3.546e-12   |\n",
      "   23    |   1.105e-11   |   4.024e-12   |\n",
      "   24    |   2.730e-12   |   9.939e-13   |\n",
      "   25    |   4.050e-12   |   1.474e-12   |\n",
      "   26    |   1.513e-13   |   5.509e-14   |\n",
      "   27    |   2.412e-14   |   8.780e-15   |\n",
      "   28    |   4.359e-14   |   1.587e-14   |\n",
      "   29    |   1.750e-15   |   6.374e-16   |\n",
      "   30    |   1.403e-15   |   5.109e-16   |\n",
      "   31    |   6.923e-16   |   2.523e-16   |\n",
      "   32    |   6.147e-16   |   2.235e-16   |\n",
      "   33    |   8.066e-16   |   2.933e-16   |\n",
      "   34    |   6.859e-16   |   2.493e-16   |\n",
      "   35    |   7.646e-16   |   2.779e-16   |\n",
      "   36    |   7.067e-16   |   2.567e-16   |\n",
      "   37    |   7.486e-16   |   2.723e-16   |\n",
      "   38    |   7.619e-16   |   2.777e-16   |\n",
      "   39    |   6.525e-16   |   2.368e-16   |\n",
      "   40    |   8.426e-16   |   3.071e-16   |\n",
      "   41    |   7.665e-16   |   2.793e-16   |\n",
      "   42    |   6.827e-16   |   2.484e-16   |\n",
      "   43    |   6.793e-16   |   2.466e-16   |\n",
      "   44    |   7.329e-16   |   2.662e-16   |\n",
      "   45    |   6.646e-16   |   2.411e-16   |\n",
      "   46    |   6.197e-16   |   2.255e-16   |\n",
      "   47    |   6.507e-16   |   2.365e-16   |\n",
      "   48    |   6.692e-16   |   2.441e-16   |\n",
      "   49    |   6.701e-16   |   2.441e-16   |\n",
      "   50    |   7.269e-16   |   2.644e-16   |\n",
      "========================================== \n",
      "\n",
      "Solver status (LVR-FR): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Learning rate: 0.9266742169822437\n",
      "Solver: SAGA-Forward-Reflected Method for Equations ...\n",
      "========================================== \n",
      "  Iters  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   6.868e-01   |   2.500e-01   |\n",
      "   2     |   1.017e+00   |   3.701e-01   |\n",
      "   3     |   5.904e-01   |   2.149e-01   |\n",
      "   4     |   4.414e-01   |   1.607e-01   |\n",
      "   5     |   3.104e-01   |   1.130e-01   |\n",
      "   6     |   1.928e-01   |   7.020e-02   |\n",
      "   7     |   1.387e-01   |   5.049e-02   |\n",
      "   8     |   8.044e-02   |   2.928e-02   |\n",
      "   9     |   5.434e-02   |   1.978e-02   |\n",
      "   10    |   3.842e-02   |   1.399e-02   |\n",
      "   11    |   2.504e-02   |   9.117e-03   |\n",
      "   12    |   1.591e-02   |   5.792e-03   |\n",
      "   13    |   1.244e-02   |   4.528e-03   |\n",
      "   14    |   6.725e-03   |   2.448e-03   |\n",
      "   15    |   5.007e-03   |   1.823e-03   |\n",
      "   16    |   2.958e-03   |   1.077e-03   |\n",
      "   17    |   1.711e-03   |   6.228e-04   |\n",
      "   18    |   1.338e-03   |   4.871e-04   |\n",
      "   19    |   9.689e-04   |   3.527e-04   |\n",
      "   20    |   6.169e-04   |   2.246e-04   |\n",
      "   21    |   3.763e-04   |   1.370e-04   |\n",
      "   22    |   2.710e-04   |   9.864e-05   |\n",
      "   23    |   1.606e-04   |   5.847e-05   |\n",
      "   24    |   1.052e-04   |   3.829e-05   |\n",
      "   25    |   6.707e-05   |   2.442e-05   |\n",
      "   26    |   4.985e-05   |   1.815e-05   |\n",
      "   27    |   3.776e-05   |   1.374e-05   |\n",
      "   28    |   2.076e-05   |   7.558e-06   |\n",
      "   29    |   1.530e-05   |   5.570e-06   |\n",
      "   30    |   7.963e-06   |   2.899e-06   |\n",
      "   31    |   6.651e-06   |   2.421e-06   |\n",
      "   32    |   3.502e-06   |   1.275e-06   |\n",
      "   33    |   2.800e-06   |   1.019e-06   |\n",
      "   34    |   1.848e-06   |   6.726e-07   |\n",
      "   35    |   1.281e-06   |   4.664e-07   |\n",
      "   36    |   7.800e-07   |   2.839e-07   |\n",
      "   37    |   5.636e-07   |   2.052e-07   |\n",
      "   38    |   3.402e-07   |   1.238e-07   |\n",
      "   39    |   2.305e-07   |   8.390e-08   |\n",
      "   40    |   1.481e-07   |   5.391e-08   |\n",
      "   41    |   1.210e-07   |   4.405e-08   |\n",
      "   42    |   7.142e-08   |   2.600e-08   |\n",
      "   43    |   4.993e-08   |   1.818e-08   |\n",
      "   44    |   2.666e-08   |   9.706e-09   |\n",
      "   45    |   1.890e-08   |   6.879e-09   |\n",
      "   46    |   1.278e-08   |   4.654e-09   |\n",
      "   47    |   8.592e-09   |   3.128e-09   |\n",
      "   48    |   5.066e-09   |   1.844e-09   |\n",
      "   49    |   3.906e-09   |   1.422e-09   |\n",
      "   50    |   2.514e-09   |   9.151e-10   |\n",
      "========================================== \n",
      "\n",
      "Solver status (SGA-FR): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Learning rate: 0.020673639948917348\n",
      "Solver: Variance-Reduced Forward-Reflected-Backward Splitting (Alacaoglu et al 2021) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   6.128e-02   |   1.000e+00   |\n",
      "   2     |   4.294e-02   |   7.006e-01   |\n",
      "   3     |   2.551e-02   |   4.162e-01   |\n",
      "   4     |   2.200e-02   |   3.590e-01   |\n",
      "   5     |   1.469e-02   |   2.398e-01   |\n",
      "   6     |   1.208e-02   |   1.970e-01   |\n",
      "   7     |   9.050e-03   |   1.477e-01   |\n",
      "   8     |   7.981e-03   |   1.302e-01   |\n",
      "   9     |   8.084e-03   |   1.319e-01   |\n",
      "   10    |   5.054e-03   |   8.247e-02   |\n",
      "   11    |   3.546e-03   |   5.786e-02   |\n",
      "   12    |   2.993e-03   |   4.884e-02   |\n",
      "   13    |   2.153e-03   |   3.514e-02   |\n",
      "   14    |   1.629e-03   |   2.658e-02   |\n",
      "   15    |   1.158e-03   |   1.890e-02   |\n",
      "   16    |   1.047e-03   |   1.708e-02   |\n",
      "   17    |   7.704e-04   |   1.257e-02   |\n",
      "   18    |   5.159e-04   |   8.418e-03   |\n",
      "   19    |   4.498e-04   |   7.340e-03   |\n",
      "   20    |   3.276e-04   |   5.346e-03   |\n",
      "   21    |   2.538e-04   |   4.141e-03   |\n",
      "   22    |   2.054e-04   |   3.352e-03   |\n",
      "   23    |   1.650e-04   |   2.693e-03   |\n",
      "   24    |   1.259e-04   |   2.054e-03   |\n",
      "   25    |   8.540e-05   |   1.393e-03   |\n",
      "   26    |   6.406e-05   |   1.045e-03   |\n",
      "   27    |   5.191e-05   |   8.471e-04   |\n",
      "   28    |   4.145e-05   |   6.764e-04   |\n",
      "   29    |   4.110e-05   |   6.706e-04   |\n",
      "   30    |   2.478e-05   |   4.043e-04   |\n",
      "   31    |   2.197e-05   |   3.585e-04   |\n",
      "   32    |   1.486e-05   |   2.425e-04   |\n",
      "   33    |   1.087e-05   |   1.774e-04   |\n",
      "   34    |   8.485e-06   |   1.384e-04   |\n",
      "   35    |   7.118e-06   |   1.161e-04   |\n",
      "   36    |   5.776e-06   |   9.425e-05   |\n",
      "   37    |   4.196e-06   |   6.847e-05   |\n",
      "   38    |   3.169e-06   |   5.172e-05   |\n",
      "   39    |   2.911e-06   |   4.751e-05   |\n",
      "   40    |   1.905e-06   |   3.108e-05   |\n",
      "   41    |   1.471e-06   |   2.400e-05   |\n",
      "   42    |   1.214e-06   |   1.981e-05   |\n",
      "   43    |   8.782e-07   |   1.433e-05   |\n",
      "   44    |   6.734e-07   |   1.099e-05   |\n",
      "   45    |   5.270e-07   |   8.599e-06   |\n",
      "   46    |   4.437e-07   |   7.241e-06   |\n",
      "   47    |   3.191e-07   |   5.207e-06   |\n",
      "   48    |   2.396e-07   |   3.910e-06   |\n",
      "   49    |   1.850e-07   |   3.018e-06   |\n",
      "   50    |   1.276e-07   |   2.083e-06   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VRFRBS): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "Learning rate: 0.3793272250906888\n",
      "Solver: Variance-Reduced Extragradient Method (Alacaoglu & Malitsky 2022) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     |   ||G(x)||    \n",
      " ------------------------------------------\n",
      "   1     |   9.444e-01   |   8.399e-01   |\n",
      "   2     |   2.444e-01   |   3.909e-01   |\n",
      "   3     |   1.767e-01   |   2.551e-01   |\n",
      "   4     |   1.064e-01   |   1.632e-01   |\n",
      "   5     |   5.180e-02   |   7.404e-02   |\n",
      "   6     |   3.170e-02   |   4.903e-02   |\n",
      "   7     |   2.308e-02   |   3.841e-02   |\n",
      "   8     |   2.243e-02   |   3.109e-02   |\n",
      "   9     |   1.198e-02   |   1.614e-02   |\n",
      "   10    |   8.504e-03   |   1.316e-02   |\n",
      "   11    |   5.612e-03   |   8.501e-03   |\n",
      "   12    |   5.658e-03   |   8.653e-03   |\n",
      "   13    |   4.700e-03   |   6.961e-03   |\n",
      "   14    |   2.927e-03   |   4.241e-03   |\n",
      "   15    |   2.419e-03   |   3.503e-03   |\n",
      "   16    |   1.247e-03   |   1.858e-03   |\n",
      "   17    |   6.633e-04   |   9.603e-04   |\n",
      "   18    |   3.069e-04   |   4.432e-04   |\n",
      "   19    |   3.219e-04   |   4.256e-04   |\n",
      "   20    |   2.441e-04   |   3.492e-04   |\n",
      "   21    |   1.437e-04   |   2.444e-04   |\n",
      "   22    |   7.950e-05   |   1.203e-04   |\n",
      "   23    |   8.278e-05   |   1.254e-04   |\n",
      "   24    |   5.463e-05   |   7.849e-05   |\n",
      "   25    |   4.780e-05   |   7.777e-05   |\n",
      "   26    |   4.314e-05   |   6.018e-05   |\n",
      "   27    |   4.049e-05   |   6.622e-05   |\n",
      "   28    |   2.814e-05   |   4.093e-05   |\n",
      "   29    |   2.308e-05   |   3.419e-05   |\n",
      "   30    |   1.670e-05   |   2.391e-05   |\n",
      "   31    |   1.008e-05   |   8.960e-06   |\n",
      "   32    |   4.984e-06   |   7.068e-06   |\n",
      "   33    |   4.207e-06   |   3.741e-06   |\n",
      "   34    |   2.412e-06   |   3.922e-06   |\n",
      "   35    |   1.166e-06   |   2.024e-06   |\n",
      "   36    |   1.013e-06   |   1.686e-06   |\n",
      "   37    |   6.504e-07   |   1.043e-06   |\n",
      "   38    |   3.872e-07   |   7.068e-07   |\n",
      "   39    |   3.042e-07   |   4.392e-07   |\n",
      "   40    |   2.476e-07   |   3.686e-07   |\n",
      "   41    |   1.350e-07   |   1.955e-07   |\n",
      "   42    |   1.105e-07   |   1.672e-07   |\n",
      "   43    |   6.356e-08   |   1.038e-07   |\n",
      "   44    |   2.161e-08   |   3.348e-08   |\n",
      "   45    |   7.936e-09   |   1.268e-08   |\n",
      "   46    |   8.999e-09   |   8.003e-09   |\n",
      "   47    |   3.443e-09   |   5.082e-09   |\n",
      "   48    |   1.390e-09   |   2.040e-09   |\n",
      "   49    |   8.853e-10   |   1.283e-09   |\n",
      "   50    |   4.228e-10   |   6.580e-10   |\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 # Set this value to 10 to run 10 problem instances\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": "683cd709-bb49-409b-b908-d0de6073e115",
   "metadata": {},
   "source": [
    "## Plot Results of The Experiments\n",
    "This section plots the results of our experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "3253152e-9292-4b76-a4e5-f993f872bd45",
   "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": 9,
   "id": "05af8bec-6af7-4d9a-82db-e81156359d43",
   "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": 10,
   "id": "a24a749e-4cb8-4f6a-adfa-5d97145b68f1",
   "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_exam1_b.pdf\", format=\"pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4e0d224-e550-43d4-8a7e-ccca8f075722",
   "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
}
