{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b677a86b-802b-49c1-a8bd-73ae655eb687",
   "metadata": {},
   "source": [
    "## Example 2: Regularized Logistic Regression with Ambiguous Features\n",
    "We consider the following convex-concave minimax problem:\n",
    "\\begin{equation}\n",
    "\\min_{w \\in\\mathbb{R}^d} \\max_{v\\in \\mathbb{R}^m } \\Big\\{ \\phi(w, v) := \\frac{1}{N} \\sum_{i=1}^{N} \\sum_{j=1}^m v_j  \\ell ( y_i \\langle w, X_{ij}\\rangle ) + \\lambda R(w) - \\delta_{\\Delta_m}(v) \\Big\\},\n",
    "\\end{equation}\n",
    "where $R(w) := \\Vert w \\Vert_1$ is an $\\ell_1$-norm regularizer, $\\lambda > 0$ is a regularization parameter, and $\\delta_{\\Delta_m}$ is the indicator of $\\Delta_m$."
   ]
  },
  {
   "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.ni_solvers as solver\n",
    "\n",
    "import pickle\n",
    "import pandas as pd\n",
    "from   sklearn.datasets import load_svmlight_file\n",
    "from   sklearn import preprocessing as dp"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1f23bbd0-3f37-4ec9-81d9-6cba0056b8be",
   "metadata": {},
   "source": [
    "## Implement a Power Method to Compute Matrix Norms\n",
    "We implement a power method to evalute the norm of a matrix."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9dd469ad-14ec-4f32-af59-f0404df0569a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def power_method(K, tol=1e-6, max_iter=100):\n",
    "    \"\"\"\n",
    "    Function: Computes the spectral norm of a matrix K using the power method.\n",
    "    Args:\n",
    "        K: The input matrix.\n",
    "        tol: Tolerance for convergence.\n",
    "        max_iter: Maximum number of iterations.\n",
    "    Returns:\n",
    "        An approximation of the spectral norm.\n",
    "    \"\"\"\n",
    "\n",
    "    m, n = K.shape\n",
    "    # Initialize a random vector\n",
    "    x = np.random.rand(n)\n",
    "    x /= np.linalg.norm(x)\n",
    "\n",
    "    for _ in range(max_iter):\n",
    "        y = K.dot(x)\n",
    "        x_new = K.T.dot(y)\n",
    "        x_new /= np.linalg.norm(x_new)\n",
    "        lambda_ = np.linalg.norm(y)\n",
    "\n",
    "        if np.linalg.norm(x_new - x) < tol:\n",
    "            break\n",
    "        x = x_new\n",
    "\n",
    "    return lambda_"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9b0cab44-c08d-43a6-8d9c-43668d164e4f",
   "metadata": {},
   "source": [
    "## Evaluate The Resolvent Operators\n",
    "Define the resovent operator of $T = [\\partial{f}, \\partial{g}]$, where $f$ and $g$ are the indicators of the standard simplexes in $\\mathbb{R}^{p_1}$ and $\\mathbb{R}^{p_2}$, respectively."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4d5a03c5-2087-4e0a-afd0-face9b970b62",
   "metadata": {},
   "outputs": [],
   "source": [
    "def projection_on_simplex(u, s=1):\n",
    "    n_u   = u.shape[0]\n",
    "    us    = np.sort(u)[::-1]\n",
    "    cssv  = np.cumsum(us) - s\n",
    "    ind   = np.arange(n_u) + 1\n",
    "    cond  = us - cssv / ind > 0\n",
    "    rho   = ind[cond][-1]\n",
    "    theta = cssv[cond][-1] / float(rho)\n",
    "    return np.maximum(u - theta, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "72a86617-89c4-4bc0-b618-63f4098b5ac7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def l1_prox(x, lambda_):\n",
    "  return np.sign(x) * np.maximum(np.abs(x) - lambda_, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1bc15e88-c2ac-44f0-8419-cbe0bb8a0977",
   "metadata": {},
   "outputs": [],
   "source": [
    "def JTx_op_eval(data, x, eta):\n",
    "    p1, p2 = data['p1'], data['p2']\n",
    "    rho    = data['rho']\n",
    "    u, v   = x[0:p1], x[p1:p1+p2]\n",
    "    u_p    = l1_prox(u, eta*rho)\n",
    "    v_p    = projection_on_simplex(v)\n",
    "    return np.concatenate((u_p, v_p), axis=0)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e13801fe-7f6b-48d6-8aba-bc627bec58db",
   "metadata": {},
   "source": [
    "## Evaluate The Operator $Gx$\n",
    "Define the operator $Gx$ for the regularized logistic regression example."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "45837445-0b05-46d7-b8c0-04e5d08a7e01",
   "metadata": {},
   "outputs": [],
   "source": [
    "def logistic_loss(tau, s):\n",
    "    exp1 = np.exp(tau)\n",
    "    return np.log(1 + exp1) - tau*s, exp1/(1 + exp1) - s\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2730b330-8391-410d-a607-ccb231edd706",
   "metadata": {},
   "outputs": [],
   "source": [
    "def Gx_op_eval(data, x, mb_id, mb_size):\n",
    "    X  = data['X']\n",
    "    y  = data['y']\n",
    "    p1 = data['p1']\n",
    "    n  = data['n']\n",
    "    \n",
    "    m = len(X)\n",
    "    w = x[0:p1]\n",
    "    v = x[p1:p1+m]\n",
    "    \n",
    "    Gw = np.zeros(p1)\n",
    "    Gv = np.zeros(m)\n",
    "    for i in range(m):\n",
    "        Xi    = X[i][mb_id, :]\n",
    "        l_val, dl_val = logistic_loss(Xi.dot(w), y[mb_id])\n",
    "        Gw    += (v[i]/mb_size)*Xi.T.dot(dl_val)\n",
    "        Gv[i] = np.mean(l_val)\n",
    "        \n",
    "    return np.concatenate((Gw, -Gv))    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c418fed4-f7a6-454b-930b-224cc968d67b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def Gbx_op_eval(data, x, mb_id, mb_size):\n",
    "    X  = data['X']\n",
    "    y  = data['y']\n",
    "    p1 = data['p1']\n",
    "    n  = data['n']\n",
    "    \n",
    "    m = len(X)\n",
    "    w = x[0:p1]\n",
    "    v = x[p1:p1+m]\n",
    "    \n",
    "    Gwi = np.zeros((p1, mb_size))\n",
    "    Gvi = np.zeros((m, mb_size))\n",
    "    Gw  = np.zeros(p1)\n",
    "    Gv  = np.zeros(m)\n",
    "    for i in range(m):\n",
    "        Xi = X[i][mb_id, :]\n",
    "        l_val, dl_val = logistic_loss(Xi.dot(w), y[mb_id])\n",
    "        Gwi += v[i]*dl_val*Xi.T\n",
    "        Gvi[i,:] = l_val\n",
    "    Gxb = np.concatenate((Gwi, -Gvi))\n",
    "\n",
    "    return np.mean(Gxb, axis=1), Gxb\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "634a700a-7d40-407d-a1cd-81092c5562df",
   "metadata": {},
   "source": [
    "## Preprocess The Input Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "8f66ce84-58ff-4d5c-b3e9-ba2b7dd612e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def preprocess_real_data(file_name, m=5, noise_radius = 0.5, reg_par=5e-4):\n",
    "\n",
    "    # Load the dataset\n",
    "    X_train, y_nominal = load_svmlight_file(file_name)\n",
    "    X_nominal  = X_train.toarray()\n",
    "    y_nominal  = (y_nominal + 1)/2\n",
    "    empty_rows = np.where(np.all(X_nominal == 0, axis=1))[0]\n",
    "    X_nominal  = np.delete(X_nominal, empty_rows, axis=0)\n",
    "    y_nominal  = np.delete(y_nominal, empty_rows)\n",
    "                \n",
    "    ## normalize data to make each sample to have norm one.\n",
    "    X_nominal  = dp.normalize(X_nominal, norm='l2', axis=1)\n",
    "    ##X_nominal = X_nominal/np.sum(X_nominal, axis=1, keepdims=True)\n",
    "    ##X_nominal = X_nominal/power_method(X_nominal, tol=1e-6, max_iter=20)\n",
    "    \n",
    "    \n",
    "    n  = X_nominal.shape[0]\n",
    "    p1 = X_nominal.shape[1] # add bias term.\n",
    "    p2 = m\n",
    "    print(\"Data dimension: (n, p1, p2) = (\", n, p1, p2, \") ...\")\n",
    "\n",
    "    ## Compute the Lipschitz constant.\n",
    "    norm_X = power_method(X_nominal, tol=1e-6, max_iter=20)\n",
    "    Lips = norm_X\n",
    "    print(\"The Lipschitz constant: \", Lips)\n",
    "    \n",
    "    ## add the column of one to handle bias term.\n",
    "    ones_column = np.ones((X_nominal.shape[0], 1))\n",
    "    X  = [ np.hstack( (ones_column, X_nominal + noise_radius*np.random.randn(n, p1) ) ) for _ in range(p2)]\n",
    "    \n",
    "    p1 += 1 # add column of ones.\n",
    "    p  = p1 + p2\n",
    "\n",
    "    \n",
    "    return dict({'X': X, 'y': y_nominal, 'p1': p1, 'p2': p2, 'n': n, 'p': p, 'rho': reg_par, 'Lips': Lips, 'L': Lips})\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7fdfa4be-50b9-43a7-b88c-c937286a28a3",
   "metadata": {},
   "source": [
    "## Set Default Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d6d9a364-a8b4-4d5d-b4f0-7b743c10a530",
   "metadata": {},
   "outputs": [],
   "source": [
    "## set default parameters\n",
    "my_verbose       = 0\n",
    "def_gamma        = 0.75\n",
    "def_lr           = 0.5\n",
    "def_max_iters    = 10000\n",
    "def_tol          = 1e-20\n",
    "def_n_max_epochs = 100\n",
    "my_is_term       = False ## using termination condition or not.\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8ca8ec92-9251-4783-9df3-d34e87e4cdd9",
   "metadata": {},
   "source": [
    "## Prepare to Run All Algorithms at Once"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "0ea44591-5aea-4f34-8b2d-4544f4bebe6d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def OneRun(my_data, x0, **kwargs):\n",
    "    \n",
    "    ## check the problem size.\n",
    "    print(\"Problem size: n = \", my_data['n'], \", p = \", my_data['p'])\n",
    "\n",
    "    ## Extract information from the data.\n",
    "    Lips = my_data['Lips']\n",
    "    n    = my_data['n']\n",
    "    p    = my_data['p']\n",
    "    all_outputs  = []\n",
    "    def_mb_size  = int(n**0.67)\n",
    "\n",
    "    ## Optimistic gradient method\n",
    "    print('We are running the OG algorithm ...')\n",
    "    my_max_iters = def_n_max_epochs\n",
    "    my_lr1       = kwargs.pop( 'my_lr1', 1.0/Lips )\n",
    "    print(' + The learning rate: eta = ', my_lr1)\n",
    "    output1      = solver.OGA(my_data, Gx_op_eval, JTx_op_eval, x0, gamma=0.5, \\\n",
    "                              eta=my_lr1, verbose=my_verbose, n_max_iters=my_max_iters, \\\n",
    "                              tol=def_tol, is_term = my_is_term, print_step = 1)\n",
    "    print(\"Solver status (OG):     \", output1[\"message\"])\n",
    "    all_outputs.append(output1)\n",
    "    \n",
    "    ## Double-loop SVRG-Forward Reflected method\n",
    "    print('We are running the double-loop SVR-FR algorithm ...')\n",
    "    my_mb_size2     = int(0.5*n**0.67)  # default value.\n",
    "    my_inner_iters2 = int(n/my_mb_size2)\n",
    "    my_lr2          = kwargs.pop( 'my_lr2', 0.5/Lips )\n",
    "    print(' + The learning rate: eta = ', my_lr2)\n",
    "    output2         = solver.Vr_FRA(my_data, Gx_op_eval, JTx_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 (VR-FR):  \", output2[\"message\"])\n",
    "    all_outputs.append(output2)\n",
    "    \n",
    "    ## Loopless SVRG-Forward Reflected method\n",
    "    print('We are running the loopless SVRG-FR algorithm ...')\n",
    "    my_prob3    = 1.0/(n**0.33)    # default value\n",
    "    my_mb_size3 = int(0.5*n**0.67) # default value\n",
    "    my_lr3      = kwargs.pop( 'my_lr3', 0.5/Lips )\n",
    "    print(' + The learning rate: eta = ', my_lr3)\n",
    "    output3      = solver.LVr_FRA(my_data, Gx_op_eval, JTx_op_eval, x0, mb_size=my_mb_size3, prob=my_prob3,\\\n",
    "                                  gamma=def_gamma, eta=my_lr3, verbose=my_verbose, n_epochs=def_n_max_epochs,\\\n",
    "                                  tol=def_tol, is_term = my_is_term)\n",
    "    print(\"Solver status (LVR-FR): \", output3[\"message\"])\n",
    "    all_outputs.append(output3)\n",
    "\n",
    "    ## Test SAGA-FR method.\n",
    "    print('We are running the SAGA-FR algorithm ...')\n",
    "    my_gamma6   = def_gamma\n",
    "    my_mb_size6 = int(0.5*n**0.67)  # default value\n",
    "    my_lr6      = kwargs.pop( 'my_lr6', 0.5/Lips )\n",
    "    print(' + The learning rate: eta = ', my_lr6)\n",
    "    output6     = solver.Saga_FRA(my_data, Gx_op_eval, Gbx_op_eval, JTx_op_eval, x0, mb_size=my_mb_size6, \\\n",
    "                                  eta=my_lr6, gamma=my_gamma6, verbose=my_verbose, \\\n",
    "                                  n_epochs=def_n_max_epochs, 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",
    "    print('We are running the FRBS algorithm ...')\n",
    "    #my_prob4   = np.minimum(20.0/(n**0.5), 0.99) ## Work well\n",
    "    #my_prob4    = np.minimum(50.0/(n**0.5), 0.99) # work best\n",
    "    my_prob4    = 1.0/(n**0.33)    # default value\n",
    "    my_mb_size4 = int(0.5*n**0.67) # default value\n",
    "    # Theoretical learning rate\n",
    "    my_lr4      = kwargs.pop( 'my_lr4', 0.95*(1 - np.sqrt(1-my_prob4))/(2.0*Lips) )\n",
    "    print(' + The learning rate: eta = ', my_lr4)\n",
    "    output4     = solver.Vr_FRBSA(my_data, Gx_op_eval, JTx_op_eval, x0, mb_size=my_mb_size4, \\\n",
    "                                  prob=my_prob4, eta=my_lr4, verbose=my_verbose, \\\n",
    "                                  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",
    "    print('We are running the SVRG-EG algorithm ...')\n",
    "    ## my_prob5    = np.minimum(20.0/(n**0.5), 0.99); # work best\n",
    "    my_prob5    = 1.0/(n**0.33)    # default value\n",
    "    my_mb_size5 = int(0.5*n**0.67) # default value\n",
    "    ## other parameters\n",
    "    my_alpha5   = 1 - my_prob5 \n",
    "    my_lr5      = kwargs.pop( 'my_lr5', 0.95*np.sqrt(1-my_alpha5)/Lips )\n",
    "    print(' + The learning rate: eta = ', my_lr1)\n",
    "    output5     = solver.Vr_EGA(my_data, Gx_op_eval, JTx_op_eval, x0, mb_size=my_mb_size5, \\\n",
    "                                prob=my_prob5, eta=my_lr5, alpha=my_alpha5, verbose=my_verbose, \\\n",
    "                                n_epochs=def_n_max_epochs, 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, dict({'n': n, 'p': p})\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c0144e5e-aedc-43df-9f2d-4d6e733632b8",
   "metadata": {},
   "source": [
    "## Run Experiment 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "1cc1c888-b026-43ff-859c-789724da28c8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "We are solving problem:  data/a9a.txt\n",
      "Data dimension: (n, p1, p2) = ( 32561 123 10 ) ...\n",
      "The Lipschitz constant:  121.42676567184309\n",
      "Problem size: n =  32561 , p =  134\n",
      "We are running the OG algorithm ...\n",
      " + The learning rate: eta =  0.411770829300728\n",
      "Solver: Optimistic Gradient Method for Generalized Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   0     |   1.446e+00   |   1.000e+00   |\n",
      "   1     |   4.534e-01   |   1.308e-01   |\n",
      "   2     |   1.492e-01   |   1.439e-01   |\n",
      "   3     |   1.297e-01   |   1.400e-01   |\n",
      "   4     |   1.269e-01   |   1.362e-01   |\n",
      "   5     |   1.229e-01   |   1.327e-01   |\n",
      "   6     |   1.196e-01   |   1.291e-01   |\n",
      "   7     |   1.162e-01   |   1.255e-01   |\n",
      "   8     |   1.128e-01   |   1.219e-01   |\n",
      "   9     |   1.095e-01   |   1.184e-01   |\n",
      "   10    |   1.061e-01   |   1.148e-01   |\n",
      "   11    |   1.028e-01   |   1.112e-01   |\n",
      "   12    |   9.956e-02   |   1.077e-01   |\n",
      "   13    |   9.635e-02   |   1.042e-01   |\n",
      "   14    |   9.320e-02   |   1.008e-01   |\n",
      "   15    |   9.012e-02   |   9.746e-02   |\n",
      "   16    |   8.710e-02   |   9.417e-02   |\n",
      "   17    |   8.417e-02   |   9.096e-02   |\n",
      "   18    |   8.132e-02   |   8.782e-02   |\n",
      "   19    |   7.855e-02   |   8.478e-02   |\n",
      "   20    |   7.587e-02   |   8.182e-02   |\n",
      "   21    |   7.328e-02   |   7.896e-02   |\n",
      "   22    |   7.078e-02   |   7.603e-02   |\n",
      "   23    |   6.815e-02   |   7.336e-02   |\n",
      "   24    |   6.581e-02   |   7.080e-02   |\n",
      "   25    |   6.361e-02   |   6.834e-02   |\n",
      "   26    |   6.150e-02   |   6.597e-02   |\n",
      "   27    |   5.948e-02   |   6.370e-02   |\n",
      "   28    |   5.755e-02   |   6.147e-02   |\n",
      "   29    |   5.560e-02   |   5.939e-02   |\n",
      "   30    |   5.385e-02   |   5.741e-02   |\n",
      "   31    |   5.218e-02   |   5.553e-02   |\n",
      "   32    |   5.059e-02   |   5.372e-02   |\n",
      "   33    |   4.908e-02   |   5.200e-02   |\n",
      "   34    |   4.764e-02   |   5.032e-02   |\n",
      "   35    |   4.620e-02   |   4.873e-02   |\n",
      "   36    |   4.487e-02   |   4.724e-02   |\n",
      "   37    |   4.364e-02   |   4.584e-02   |\n",
      "   38    |   4.248e-02   |   4.451e-02   |\n",
      "   39    |   4.138e-02   |   4.325e-02   |\n",
      "   40    |   4.034e-02   |   4.201e-02   |\n",
      "   41    |   3.928e-02   |   4.088e-02   |\n",
      "   42    |   3.836e-02   |   3.982e-02   |\n",
      "   43    |   3.748e-02   |   3.881e-02   |\n",
      "   44    |   3.665e-02   |   3.784e-02   |\n",
      "   45    |   3.586e-02   |   3.690e-02   |\n",
      "   46    |   3.508e-02   |   3.603e-02   |\n",
      "   47    |   3.438e-02   |   3.522e-02   |\n",
      "   48    |   3.372e-02   |   3.446e-02   |\n",
      "   49    |   3.309e-02   |   3.373e-02   |\n",
      "   50    |   3.250e-02   |   3.305e-02   |\n",
      "   51    |   3.194e-02   |   3.240e-02   |\n",
      "   52    |   3.141e-02   |   3.179e-02   |\n",
      "   53    |   3.091e-02   |   3.121e-02   |\n",
      "   54    |   3.044e-02   |   3.067e-02   |\n",
      "   55    |   2.999e-02   |   3.015e-02   |\n",
      "   56    |   2.956e-02   |   2.960e-02   |\n",
      "   57    |   2.905e-02   |   2.913e-02   |\n",
      "   58    |   2.868e-02   |   2.870e-02   |\n",
      "   59    |   2.831e-02   |   2.828e-02   |\n",
      "   60    |   2.797e-02   |   2.789e-02   |\n",
      "   61    |   2.764e-02   |   2.751e-02   |\n",
      "   62    |   2.733e-02   |   2.716e-02   |\n",
      "   63    |   2.704e-02   |   2.682e-02   |\n",
      "   64    |   2.675e-02   |   2.650e-02   |\n",
      "   65    |   2.648e-02   |   2.619e-02   |\n",
      "   66    |   2.623e-02   |   2.590e-02   |\n",
      "   67    |   2.598e-02   |   2.562e-02   |\n",
      "   68    |   2.574e-02   |   2.535e-02   |\n",
      "   69    |   2.551e-02   |   2.509e-02   |\n",
      "   70    |   2.529e-02   |   2.485e-02   |\n",
      "   71    |   2.508e-02   |   2.457e-02   |\n",
      "   72    |   2.480e-02   |   2.434e-02   |\n",
      "   73    |   2.460e-02   |   2.412e-02   |\n",
      "   74    |   2.441e-02   |   2.391e-02   |\n",
      "   75    |   2.423e-02   |   2.370e-02   |\n",
      "   76    |   2.405e-02   |   2.351e-02   |\n",
      "   77    |   2.387e-02   |   2.331e-02   |\n",
      "   78    |   2.370e-02   |   2.313e-02   |\n",
      "   79    |   2.354e-02   |   2.294e-02   |\n",
      "   80    |   2.337e-02   |   2.277e-02   |\n",
      "   81    |   2.322e-02   |   2.259e-02   |\n",
      "   82    |   2.306e-02   |   2.243e-02   |\n",
      "   83    |   2.291e-02   |   2.226e-02   |\n",
      "   84    |   2.273e-02   |   2.207e-02   |\n",
      "   85    |   2.257e-02   |   2.191e-02   |\n",
      "   86    |   2.242e-02   |   2.175e-02   |\n",
      "   87    |   2.228e-02   |   2.160e-02   |\n",
      "   88    |   2.213e-02   |   2.145e-02   |\n",
      "   89    |   2.199e-02   |   2.126e-02   |\n",
      "   90    |   2.177e-02   |   2.110e-02   |\n",
      "   91    |   2.164e-02   |   2.096e-02   |\n",
      "   92    |   2.151e-02   |   2.081e-02   |\n",
      "   93    |   2.137e-02   |   2.067e-02   |\n",
      "   94    |   2.124e-02   |   2.053e-02   |\n",
      "   95    |   2.111e-02   |   2.039e-02   |\n",
      "   96    |   2.096e-02   |   2.022e-02   |\n",
      "   97    |   2.080e-02   |   2.008e-02   |\n",
      "   98    |   2.067e-02   |   1.995e-02   |\n",
      "   99    |   2.054e-02   |   1.981e-02   |\n",
      "========================================== \n",
      "\n",
      "Solver status (OG):      Exceed the maximum number of epochs. Increase it to run further ...\n",
      "We are running the double-loop SVR-FR algorithm ...\n",
      " + The learning rate: eta =  0.205885414650364\n",
      "Solver: SVRG-Forward-Reflected Method for Generalized Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   0     |   1.997e+00   |   1.000e+00   |\n",
      "   1     |   9.076e-01   |   6.798e-02   |\n",
      "   2     |   7.729e-01   |   4.652e-02   |\n",
      "   3     |   5.082e-01   |   2.855e-02   |\n",
      "   4     |   3.952e-01   |   2.038e-02   |\n",
      "   5     |   3.404e-01   |   1.666e-02   |\n",
      "   6     |   3.053e-01   |   1.467e-02   |\n",
      "   7     |   2.770e-01   |   1.325e-02   |\n",
      "   8     |   2.508e-01   |   1.204e-02   |\n",
      "   9     |   2.255e-01   |   1.085e-02   |\n",
      "   10    |   2.025e-01   |   9.735e-03   |\n",
      "   11    |   1.815e-01   |   8.745e-03   |\n",
      "   12    |   1.610e-01   |   7.805e-03   |\n",
      "   13    |   1.429e-01   |   6.906e-03   |\n",
      "   14    |   1.263e-01   |   6.103e-03   |\n",
      "   15    |   1.116e-01   |   5.408e-03   |\n",
      "   16    |   9.817e-02   |   4.767e-03   |\n",
      "   17    |   8.607e-02   |   4.186e-03   |\n",
      "   18    |   7.485e-02   |   3.668e-03   |\n",
      "   19    |   6.440e-02   |   3.148e-03   |\n",
      "   20    |   5.564e-02   |   2.723e-03   |\n",
      "   21    |   4.736e-02   |   2.335e-03   |\n",
      "   22    |   3.893e-02   |   1.990e-03   |\n",
      "   23    |   3.265e-02   |   1.622e-03   |\n",
      "   24    |   2.766e-02   |   1.368e-03   |\n",
      "   25    |   2.328e-02   |   1.143e-03   |\n",
      "   26    |   2.021e-02   |   9.812e-04   |\n",
      "   27    |   1.719e-02   |   8.481e-04   |\n",
      "   28    |   1.463e-02   |   7.066e-04   |\n",
      "   29    |   1.293e-02   |   6.211e-04   |\n",
      "   30    |   1.165e-02   |   5.554e-04   |\n",
      "   31    |   1.044e-02   |   5.014e-04   |\n",
      "   32    |   9.487e-03   |   4.488e-04   |\n",
      "   33    |   8.675e-03   |   4.102e-04   |\n",
      "   34    |   7.934e-03   |   3.741e-04   |\n",
      "   35    |   7.321e-03   |   3.444e-04   |\n",
      "   36    |   6.783e-03   |   3.184e-04   |\n",
      "   37    |   6.295e-03   |   2.957e-04   |\n",
      "   38    |   5.882e-03   |   2.753e-04   |\n",
      "   39    |   5.519e-03   |   2.580e-04   |\n",
      "   40    |   5.205e-03   |   2.429e-04   |\n",
      "   41    |   4.931e-03   |   2.298e-04   |\n",
      "   42    |   4.694e-03   |   2.184e-04   |\n",
      "   43    |   4.487e-03   |   2.086e-04   |\n",
      "   44    |   4.304e-03   |   2.001e-04   |\n",
      "   45    |   4.150e-03   |   1.928e-04   |\n",
      "   46    |   4.018e-03   |   1.865e-04   |\n",
      "   47    |   3.902e-03   |   1.811e-04   |\n",
      "   48    |   3.804e-03   |   1.765e-04   |\n",
      "   49    |   3.720e-03   |   1.726e-04   |\n",
      "   50    |   3.650e-03   |   1.692e-04   |\n",
      "   51    |   3.583e-03   |   1.662e-04   |\n",
      "   52    |   3.529e-03   |   1.637e-04   |\n",
      "   53    |   3.479e-03   |   1.615e-04   |\n",
      "   54    |   3.437e-03   |   1.596e-04   |\n",
      "   55    |   3.022e-03   |   1.578e-04   |\n",
      "   56    |   2.924e-03   |   1.370e-04   |\n",
      "   57    |   2.891e-03   |   1.354e-04   |\n",
      "   58    |   2.861e-03   |   1.340e-04   |\n",
      "   59    |   2.832e-03   |   1.328e-04   |\n",
      "   60    |   2.807e-03   |   1.316e-04   |\n",
      "   61    |   2.782e-03   |   1.306e-04   |\n",
      "   62    |   2.758e-03   |   1.296e-04   |\n",
      "   63    |   2.739e-03   |   1.287e-04   |\n",
      "   64    |   2.720e-03   |   1.279e-04   |\n",
      "   65    |   2.699e-03   |   1.271e-04   |\n",
      "   66    |   2.684e-03   |   1.263e-04   |\n",
      "   67    |   2.667e-03   |   1.255e-04   |\n",
      "   68    |   2.652e-03   |   1.248e-04   |\n",
      "   69    |   2.637e-03   |   1.241e-04   |\n",
      "   70    |   2.618e-03   |   1.234e-04   |\n",
      "   71    |   2.601e-03   |   1.228e-04   |\n",
      "   72    |   2.587e-03   |   1.221e-04   |\n",
      "   73    |   2.575e-03   |   1.215e-04   |\n",
      "   74    |   2.559e-03   |   1.208e-04   |\n",
      "   75    |   2.542e-03   |   1.202e-04   |\n",
      "   76    |   2.529e-03   |   1.196e-04   |\n",
      "   77    |   2.513e-03   |   1.190e-04   |\n",
      "   78    |   2.501e-03   |   1.184e-04   |\n",
      "   79    |   2.485e-03   |   1.178e-04   |\n",
      "   80    |   2.474e-03   |   1.173e-04   |\n",
      "   81    |   2.462e-03   |   1.167e-04   |\n",
      "   82    |   2.448e-03   |   1.162e-04   |\n",
      "   83    |   2.096e-03   |   1.156e-04   |\n",
      "   84    |   2.011e-03   |   9.738e-05   |\n",
      "   85    |   2.000e-03   |   9.680e-05   |\n",
      "   86    |   1.985e-03   |   9.625e-05   |\n",
      "   87    |   1.974e-03   |   9.574e-05   |\n",
      "   88    |   1.960e-03   |   9.525e-05   |\n",
      "   89    |   1.950e-03   |   9.477e-05   |\n",
      "   90    |   1.940e-03   |   9.431e-05   |\n",
      "   91    |   1.930e-03   |   9.387e-05   |\n",
      "   92    |   1.919e-03   |   9.344e-05   |\n",
      "   93    |   8.520e-04   |   9.301e-05   |\n",
      "   94    |   7.299e-04   |   4.745e-05   |\n",
      "   95    |   7.108e-04   |   4.687e-05   |\n",
      "   96    |   6.984e-04   |   4.643e-05   |\n",
      "   97    |   6.886e-04   |   4.605e-05   |\n",
      "   98    |   6.800e-04   |   4.576e-05   |\n",
      "   99    |   6.688e-04   |   4.552e-05   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-FR):   Exceed the maximum number of epochs. Increase it to run further ...\n",
      "We are running the loopless SVRG-FR algorithm ...\n",
      " + The learning rate: eta =  0.205885414650364\n",
      "Solver: Loopless-SVRG-Forward-Reflected Method for Generalized Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   1     |   1.277e+00   |   8.833e-01   |\n",
      "   2     |   2.360e-02   |   1.699e-02   |\n",
      "   3     |   1.399e-02   |   1.049e-02   |\n",
      "   4     |   8.953e-03   |   7.157e-03   |\n",
      "   5     |   6.759e-03   |   5.750e-03   |\n",
      "   6     |   5.864e-03   |   5.146e-03   |\n",
      "   7     |   5.221e-03   |   4.705e-03   |\n",
      "   8     |   4.716e-03   |   4.323e-03   |\n",
      "   9     |   4.299e-03   |   4.043e-03   |\n",
      "   10    |   3.890e-03   |   3.748e-03   |\n",
      "   11    |   3.483e-03   |   3.445e-03   |\n",
      "   12    |   3.136e-03   |   3.215e-03   |\n",
      "   13    |   2.780e-03   |   2.965e-03   |\n",
      "   14    |   2.469e-03   |   2.754e-03   |\n",
      "   15    |   2.180e-03   |   2.546e-03   |\n",
      "   16    |   1.942e-03   |   2.384e-03   |\n",
      "   17    |   1.706e-03   |   2.227e-03   |\n",
      "   18    |   1.498e-03   |   2.084e-03   |\n",
      "   19    |   1.339e-03   |   1.967e-03   |\n",
      "   20    |   1.136e-03   |   1.830e-03   |\n",
      "   21    |   9.780e-04   |   1.710e-03   |\n",
      "   22    |   8.345e-04   |   1.592e-03   |\n",
      "   23    |   7.172e-04   |   1.499e-03   |\n",
      "   24    |   5.862e-04   |   1.346e-03   |\n",
      "   25    |   4.973e-04   |   1.261e-03   |\n",
      "   26    |   4.239e-04   |   1.177e-03   |\n",
      "   27    |   3.594e-04   |   1.106e-03   |\n",
      "   28    |   3.101e-04   |   1.060e-03   |\n",
      "   29    |   2.665e-04   |   1.005e-03   |\n",
      "   30    |   2.277e-04   |   9.378e-04   |\n",
      "   31    |   2.022e-04   |   9.149e-04   |\n",
      "   32    |   1.834e-04   |   9.105e-04   |\n",
      "   33    |   1.638e-04   |   8.813e-04   |\n",
      "   34    |   1.546e-04   |   8.840e-04   |\n",
      "   35    |   1.368e-04   |   8.812e-04   |\n",
      "   36    |   1.254e-04   |   8.713e-04   |\n",
      "   37    |   1.157e-04   |   8.689e-04   |\n",
      "   38    |   1.075e-04   |   8.674e-04   |\n",
      "   39    |   1.004e-04   |   8.656e-04   |\n",
      "   40    |   9.367e-05   |   8.566e-04   |\n",
      "   41    |   8.788e-05   |   8.558e-04   |\n",
      "   42    |   8.456e-05   |   8.570e-04   |\n",
      "   43    |   7.877e-05   |   8.545e-04   |\n",
      "   44    |   7.524e-05   |   8.538e-04   |\n",
      "   45    |   7.388e-05   |   8.548e-04   |\n",
      "   46    |   7.058e-05   |   8.535e-04   |\n",
      "   47    |   6.686e-05   |   8.521e-04   |\n",
      "   48    |   6.472e-05   |   8.450e-04   |\n",
      "   49    |   6.315e-05   |   8.436e-04   |\n",
      "   50    |   6.342e-05   |   8.422e-04   |\n",
      "   51    |   6.016e-05   |   8.436e-04   |\n",
      "   52    |   5.916e-05   |   8.444e-04   |\n",
      "   53    |   5.804e-05   |   8.430e-04   |\n",
      "   54    |   5.708e-05   |   8.432e-04   |\n",
      "   55    |   5.643e-05   |   8.430e-04   |\n",
      "   56    |   5.597e-05   |   8.418e-04   |\n",
      "   57    |   5.551e-05   |   8.439e-04   |\n",
      "   58    |   5.453e-05   |   8.436e-04   |\n",
      "   59    |   5.439e-05   |   8.463e-04   |\n",
      "   60    |   5.388e-05   |   8.482e-04   |\n",
      "   61    |   5.342e-05   |   8.494e-04   |\n",
      "   62    |   5.286e-05   |   8.493e-04   |\n",
      "   63    |   4.474e-05   |   8.486e-04   |\n",
      "   64    |   4.432e-05   |   8.488e-04   |\n",
      "   65    |   4.417e-05   |   8.490e-04   |\n",
      "   66    |   4.372e-05   |   8.494e-04   |\n",
      "   67    |   4.333e-05   |   8.487e-04   |\n",
      "   68    |   4.305e-05   |   8.487e-04   |\n",
      "   69    |   4.284e-05   |   8.487e-04   |\n",
      "   70    |   4.252e-05   |   8.489e-04   |\n",
      "   71    |   4.283e-05   |   8.486e-04   |\n",
      "   72    |   4.205e-05   |   8.494e-04   |\n",
      "   73    |   4.208e-05   |   8.504e-04   |\n",
      "   74    |   4.158e-05   |   8.510e-04   |\n",
      "   75    |   4.192e-05   |   8.524e-04   |\n",
      "   76    |   4.420e-05   |   8.499e-04   |\n",
      "   77    |   4.079e-05   |   8.485e-04   |\n",
      "   78    |   3.374e-05   |   8.484e-04   |\n",
      "   79    |   3.343e-05   |   8.484e-04   |\n",
      "   80    |   3.343e-05   |   8.482e-04   |\n",
      "   81    |   3.301e-05   |   8.483e-04   |\n",
      "   82    |   3.287e-05   |   8.483e-04   |\n",
      "   83    |   3.267e-05   |   8.485e-04   |\n",
      "   84    |   3.271e-05   |   8.482e-04   |\n",
      "   85    |   3.247e-05   |   8.487e-04   |\n",
      "   86    |   3.228e-05   |   8.481e-04   |\n",
      "   87    |   3.191e-05   |   8.484e-04   |\n",
      "   88    |   3.173e-05   |   8.483e-04   |\n",
      "   89    |   3.193e-05   |   8.478e-04   |\n",
      "   90    |   1.239e-05   |   8.479e-04   |\n",
      "   91    |   1.206e-05   |   8.480e-04   |\n",
      "   92    |   1.185e-05   |   8.479e-04   |\n",
      "   93    |   1.161e-05   |   8.479e-04   |\n",
      "   94    |   1.192e-05   |   8.483e-04   |\n",
      "   95    |   1.128e-05   |   8.479e-04   |\n",
      "   96    |   1.114e-05   |   8.480e-04   |\n",
      "   97    |   1.102e-05   |   8.479e-04   |\n",
      "   98    |   1.093e-05   |   8.480e-04   |\n",
      "   99    |   1.084e-05   |   8.479e-04   |\n",
      "  100    |   1.124e-05   |   8.472e-04   |\n",
      "========================================== \n",
      "\n",
      "Solver status (LVR-FR):  Exceed the maximum number of epochs. Increase it to run further ...\n",
      "We are running the SAGA-FR algorithm ...\n",
      " + The learning rate: eta =  0.205885414650364\n",
      "Solver: SAGA-Forward-Reflected Method for Generalized Equations ...\n",
      "========================================== \n",
      "  Iters  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   1     |   1.277e+00   |   8.833e-01   |\n",
      "   2     |   2.641e-02   |   1.891e-02   |\n",
      "   3     |   1.493e-02   |   1.106e-02   |\n",
      "   4     |   9.182e-03   |   7.263e-03   |\n",
      "   5     |   7.804e-03   |   6.388e-03   |\n",
      "   6     |   6.048e-03   |   5.230e-03   |\n",
      "   7     |   5.423e-03   |   4.809e-03   |\n",
      "   8     |   4.831e-03   |   4.406e-03   |\n",
      "   9     |   4.434e-03   |   4.075e-03   |\n",
      "   10    |   3.885e-03   |   3.738e-03   |\n",
      "   11    |   3.484e-03   |   3.437e-03   |\n",
      "   12    |   3.183e-03   |   3.245e-03   |\n",
      "   13    |   2.784e-03   |   2.970e-03   |\n",
      "   14    |   2.496e-03   |   2.757e-03   |\n",
      "   15    |   2.198e-03   |   2.552e-03   |\n",
      "   16    |   1.930e-03   |   2.379e-03   |\n",
      "   17    |   1.713e-03   |   2.232e-03   |\n",
      "   18    |   1.483e-03   |   2.080e-03   |\n",
      "   19    |   1.308e-03   |   1.954e-03   |\n",
      "   20    |   1.123e-03   |   1.811e-03   |\n",
      "   21    |   9.774e-04   |   1.707e-03   |\n",
      "   22    |   8.348e-04   |   1.589e-03   |\n",
      "   23    |   7.209e-04   |   1.488e-03   |\n",
      "   24    |   5.927e-04   |   1.349e-03   |\n",
      "   25    |   5.062e-04   |   1.263e-03   |\n",
      "   26    |   4.181e-04   |   1.141e-03   |\n",
      "   27    |   3.554e-04   |   1.081e-03   |\n",
      "   28    |   3.154e-04   |   1.050e-03   |\n",
      "   29    |   2.657e-04   |   1.003e-03   |\n",
      "   30    |   2.299e-04   |   9.255e-04   |\n",
      "   31    |   2.069e-04   |   9.080e-04   |\n",
      "   32    |   1.850e-04   |   8.811e-04   |\n",
      "   33    |   1.650e-04   |   8.773e-04   |\n",
      "   34    |   1.488e-04   |   8.726e-04   |\n",
      "   35    |   1.406e-04   |   8.696e-04   |\n",
      "   36    |   1.269e-04   |   8.658e-04   |\n",
      "   37    |   1.173e-04   |   8.639e-04   |\n",
      "   38    |   1.091e-04   |   8.694e-04   |\n",
      "   39    |   1.025e-04   |   8.696e-04   |\n",
      "   40    |   9.608e-05   |   8.655e-04   |\n",
      "   41    |   9.040e-05   |   8.542e-04   |\n",
      "   42    |   8.775e-05   |   8.602e-04   |\n",
      "   43    |   8.193e-05   |   8.535e-04   |\n",
      "   44    |   7.786e-05   |   8.546e-04   |\n",
      "   45    |   7.449e-05   |   8.534e-04   |\n",
      "   46    |   7.287e-05   |   8.536e-04   |\n",
      "   47    |   7.024e-05   |   8.518e-04   |\n",
      "   48    |   6.764e-05   |   8.526e-04   |\n",
      "   49    |   6.650e-05   |   8.515e-04   |\n",
      "   50    |   6.544e-05   |   8.452e-04   |\n",
      "   51    |   6.393e-05   |   8.444e-04   |\n",
      "   52    |   6.285e-05   |   8.482e-04   |\n",
      "   53    |   6.227e-05   |   8.514e-04   |\n",
      "   54    |   6.114e-05   |   8.480e-04   |\n",
      "   55    |   6.042e-05   |   8.496e-04   |\n",
      "   56    |   5.988e-05   |   8.484e-04   |\n",
      "   57    |   5.853e-05   |   8.499e-04   |\n",
      "   58    |   5.844e-05   |   8.472e-04   |\n",
      "   59    |   5.751e-05   |   8.518e-04   |\n",
      "   60    |   5.733e-05   |   8.480e-04   |\n",
      "   61    |   5.639e-05   |   8.503e-04   |\n",
      "   62    |   5.661e-05   |   8.497e-04   |\n",
      "   63    |   5.616e-05   |   8.524e-04   |\n",
      "   64    |   5.625e-05   |   8.527e-04   |\n",
      "   65    |   5.643e-05   |   8.529e-04   |\n",
      "   66    |   5.558e-05   |   8.541e-04   |\n",
      "   67    |   5.519e-05   |   8.524e-04   |\n",
      "   68    |   5.445e-05   |   8.587e-04   |\n",
      "   69    |   5.401e-05   |   8.526e-04   |\n",
      "   70    |   5.478e-05   |   8.560e-04   |\n",
      "   71    |   5.375e-05   |   8.556e-04   |\n",
      "   72    |   4.621e-05   |   8.550e-04   |\n",
      "   73    |   4.576e-05   |   8.545e-04   |\n",
      "   74    |   4.525e-05   |   8.558e-04   |\n",
      "   75    |   4.466e-05   |   8.560e-04   |\n",
      "   76    |   4.449e-05   |   8.558e-04   |\n",
      "   77    |   4.483e-05   |   8.536e-04   |\n",
      "   78    |   4.415e-05   |   8.551e-04   |\n",
      "   79    |   4.455e-05   |   8.544e-04   |\n",
      "   80    |   4.387e-05   |   8.547e-04   |\n",
      "   81    |   4.344e-05   |   8.555e-04   |\n",
      "   82    |   4.398e-05   |   8.583e-04   |\n",
      "   83    |   4.252e-05   |   8.553e-04   |\n",
      "   84    |   4.296e-05   |   8.544e-04   |\n",
      "   85    |   4.241e-05   |   8.561e-04   |\n",
      "   86    |   4.242e-05   |   8.535e-04   |\n",
      "   87    |   4.266e-05   |   8.479e-04   |\n",
      "   88    |   4.181e-05   |   8.482e-04   |\n",
      "   89    |   3.519e-05   |   8.484e-04   |\n",
      "   90    |   3.504e-05   |   8.490e-04   |\n",
      "   91    |   3.398e-05   |   8.488e-04   |\n",
      "   92    |   3.373e-05   |   8.475e-04   |\n",
      "   93    |   3.460e-05   |   8.488e-04   |\n",
      "   94    |   3.376e-05   |   8.484e-04   |\n",
      "   95    |   3.310e-05   |   8.487e-04   |\n",
      "   96    |   1.523e-05   |   8.483e-04   |\n",
      "   97    |   1.430e-05   |   8.486e-04   |\n",
      "   98    |   1.383e-05   |   8.482e-04   |\n",
      "   99    |   1.349e-05   |   8.476e-04   |\n",
      "  100    |   1.326e-05   |   8.483e-04   |\n",
      "========================================== \n",
      "\n",
      "Solver status (SAGA-FR): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "We are running the FRBS algorithm ...\n",
      " + The learning rate: eta =  0.003196630580390209\n",
      "Solver: Variance-Reduced Forward-Reflected-Backward Splitting (Alacaoglu et al 2021) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   1     |   1.265e+00   |   1.000e+00   |\n",
      "   2     |   7.048e-03   |   5.571e-03   |\n",
      "   3     |   2.216e-03   |   1.752e-03   |\n",
      "   4     |   2.178e-03   |   1.722e-03   |\n",
      "   5     |   2.126e-03   |   1.681e-03   |\n",
      "   6     |   2.086e-03   |   1.649e-03   |\n",
      "   7     |   2.039e-03   |   1.612e-03   |\n",
      "   8     |   1.981e-03   |   1.566e-03   |\n",
      "   9     |   1.919e-03   |   1.517e-03   |\n",
      "   10    |   1.873e-03   |   1.481e-03   |\n",
      "   11    |   1.835e-03   |   1.451e-03   |\n",
      "   12    |   1.776e-03   |   1.404e-03   |\n",
      "   13    |   1.722e-03   |   1.362e-03   |\n",
      "   14    |   1.568e-03   |   1.239e-03   |\n",
      "   15    |   1.521e-03   |   1.202e-03   |\n",
      "   16    |   1.584e-03   |   1.252e-03   |\n",
      "   17    |   1.523e-03   |   1.204e-03   |\n",
      "   18    |   1.454e-03   |   1.150e-03   |\n",
      "   19    |   1.421e-03   |   1.124e-03   |\n",
      "   20    |   1.397e-03   |   1.104e-03   |\n",
      "   21    |   1.360e-03   |   1.075e-03   |\n",
      "   22    |   1.316e-03   |   1.040e-03   |\n",
      "   23    |   1.274e-03   |   1.007e-03   |\n",
      "   24    |   1.198e-03   |   9.471e-04   |\n",
      "   25    |   1.180e-03   |   9.328e-04   |\n",
      "   26    |   1.145e-03   |   9.049e-04   |\n",
      "   27    |   1.109e-03   |   8.765e-04   |\n",
      "   28    |   1.070e-03   |   8.462e-04   |\n",
      "   29    |   9.972e-04   |   7.883e-04   |\n",
      "   30    |   9.875e-04   |   7.806e-04   |\n",
      "   31    |   9.662e-04   |   7.638e-04   |\n",
      "   32    |   9.445e-04   |   7.467e-04   |\n",
      "   33    |   9.048e-04   |   7.153e-04   |\n",
      "   34    |   8.638e-04   |   6.828e-04   |\n",
      "   35    |   8.404e-04   |   6.644e-04   |\n",
      "   36    |   8.317e-04   |   6.575e-04   |\n",
      "   37    |   8.041e-04   |   6.357e-04   |\n",
      "   38    |   7.599e-04   |   6.008e-04   |\n",
      "   39    |   7.574e-04   |   5.988e-04   |\n",
      "   40    |   7.296e-04   |   5.768e-04   |\n",
      "   41    |   7.047e-04   |   5.571e-04   |\n",
      "   42    |   6.913e-04   |   5.465e-04   |\n",
      "   43    |   6.741e-04   |   5.329e-04   |\n",
      "   44    |   6.532e-04   |   5.164e-04   |\n",
      "   45    |   6.332e-04   |   5.006e-04   |\n",
      "   46    |   6.047e-04   |   4.780e-04   |\n",
      "   47    |   6.055e-04   |   4.787e-04   |\n",
      "   48    |   5.910e-04   |   4.672e-04   |\n",
      "   49    |   5.770e-04   |   4.561e-04   |\n",
      "   50    |   5.583e-04   |   4.413e-04   |\n",
      "   51    |   5.465e-04   |   4.320e-04   |\n",
      "   52    |   5.262e-04   |   4.160e-04   |\n",
      "   53    |   5.259e-04   |   4.157e-04   |\n",
      "   54    |   5.164e-04   |   4.083e-04   |\n",
      "   55    |   5.078e-04   |   4.014e-04   |\n",
      "   56    |   4.911e-04   |   3.882e-04   |\n",
      "   57    |   4.810e-04   |   3.802e-04   |\n",
      "   58    |   4.777e-04   |   3.776e-04   |\n",
      "   59    |   4.616e-04   |   3.649e-04   |\n",
      "   60    |   4.641e-04   |   3.669e-04   |\n",
      "   61    |   4.530e-04   |   3.581e-04   |\n",
      "   62    |   4.392e-04   |   3.472e-04   |\n",
      "   63    |   4.430e-04   |   3.502e-04   |\n",
      "   64    |   4.362e-04   |   3.449e-04   |\n",
      "   65    |   4.304e-04   |   3.402e-04   |\n",
      "   66    |   4.205e-04   |   3.325e-04   |\n",
      "   67    |   4.146e-04   |   3.277e-04   |\n",
      "   68    |   4.134e-04   |   3.268e-04   |\n",
      "   69    |   4.091e-04   |   3.234e-04   |\n",
      "   70    |   4.019e-04   |   3.177e-04   |\n",
      "   71    |   3.973e-04   |   3.141e-04   |\n",
      "   72    |   3.943e-04   |   3.117e-04   |\n",
      "   73    |   3.901e-04   |   3.084e-04   |\n",
      "   74    |   3.845e-04   |   3.040e-04   |\n",
      "   75    |   3.832e-04   |   3.029e-04   |\n",
      "   76    |   3.788e-04   |   2.995e-04   |\n",
      "   77    |   3.755e-04   |   2.968e-04   |\n",
      "   78    |   3.670e-04   |   2.901e-04   |\n",
      "   79    |   3.702e-04   |   2.927e-04   |\n",
      "   80    |   3.637e-04   |   2.876e-04   |\n",
      "   81    |   3.639e-04   |   2.877e-04   |\n",
      "   82    |   3.610e-04   |   2.854e-04   |\n",
      "   83    |   3.585e-04   |   2.834e-04   |\n",
      "   84    |   3.555e-04   |   2.810e-04   |\n",
      "   85    |   3.524e-04   |   2.786e-04   |\n",
      "   86    |   3.485e-04   |   2.755e-04   |\n",
      "   87    |   3.473e-04   |   2.746e-04   |\n",
      "   88    |   3.443e-04   |   2.722e-04   |\n",
      "   89    |   3.430e-04   |   2.712e-04   |\n",
      "   90    |   3.390e-04   |   2.680e-04   |\n",
      "   91    |   3.384e-04   |   2.675e-04   |\n",
      "   92    |   3.362e-04   |   2.658e-04   |\n",
      "   93    |   3.309e-04   |   2.616e-04   |\n",
      "   94    |   3.289e-04   |   2.600e-04   |\n",
      "   95    |   3.265e-04   |   2.581e-04   |\n",
      "   96    |   3.213e-04   |   2.540e-04   |\n",
      "   97    |   3.258e-04   |   2.576e-04   |\n",
      "   98    |   3.238e-04   |   2.560e-04   |\n",
      "   99    |   3.212e-04   |   2.539e-04   |\n",
      "  100    |   3.198e-04   |   2.528e-04   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-FRBS): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "We are running the SVRG-EG algorithm ...\n",
      " + The learning rate: eta =  0.411770829300728\n",
      "Solver: Variance-Reduced Extragradient Method (Alacaoglu & Malitsky 2022) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   1     |   1.266e+00   |   9.830e-01   |\n",
      "   2     |   5.435e-04   |   3.647e-02   |\n",
      "   3     |   4.369e-04   |   3.646e-02   |\n",
      "   4     |   2.274e-02   |   3.546e-02   |\n",
      "   5     |   4.022e-04   |   3.471e-02   |\n",
      "   6     |   4.361e-04   |   3.471e-02   |\n",
      "   7     |   5.065e-03   |   3.202e-02   |\n",
      "   8     |   2.666e-04   |   3.136e-02   |\n",
      "   9     |   4.867e-04   |   2.949e-02   |\n",
      "   10    |   4.605e-04   |   2.776e-02   |\n",
      "   11    |   2.356e-04   |   2.664e-02   |\n",
      "   12    |   3.843e-04   |   2.603e-02   |\n",
      "   13    |   3.073e-04   |   2.431e-02   |\n",
      "   14    |   2.540e-04   |   2.270e-02   |\n",
      "   15    |   2.322e-04   |   2.168e-02   |\n",
      "   16    |   2.660e-04   |   2.117e-02   |\n",
      "   17    |   3.520e-04   |   1.984e-02   |\n",
      "   18    |   2.219e-04   |   1.936e-02   |\n",
      "   19    |   3.960e-04   |   1.936e-02   |\n",
      "   20    |   1.952e-04   |   1.802e-02   |\n",
      "   21    |   2.687e-04   |   1.716e-02   |\n",
      "   22    |   2.761e-04   |   1.637e-02   |\n",
      "   23    |   1.630e-04   |   1.598e-02   |\n",
      "   24    |   1.770e-04   |   1.491e-02   |\n",
      "   25    |   1.686e-04   |   1.493e-02   |\n",
      "   26    |   2.239e-03   |   1.426e-02   |\n",
      "   27    |   2.246e-04   |   1.333e-02   |\n",
      "   28    |   9.811e-04   |   1.250e-02   |\n",
      "   29    |   4.697e-04   |   1.174e-02   |\n",
      "   30    |   1.085e-04   |   1.066e-02   |\n",
      "   31    |   9.484e-05   |   1.019e-02   |\n",
      "   32    |   3.744e-04   |   9.331e-03   |\n",
      "   33    |   8.528e-05   |   9.180e-03   |\n",
      "   34    |   5.188e-05   |   8.910e-03   |\n",
      "   35    |   5.923e-05   |   8.539e-03   |\n",
      "   36    |   5.369e-05   |   8.216e-03   |\n",
      "   37    |   7.944e-05   |   7.921e-03   |\n",
      "   38    |   9.415e-05   |   7.921e-03   |\n",
      "   39    |   8.301e-05   |   7.830e-03   |\n",
      "   40    |   6.468e-05   |   7.655e-03   |\n",
      "   41    |   1.563e-04   |   7.441e-03   |\n",
      "   42    |   5.540e-05   |   7.369e-03   |\n",
      "   43    |   5.869e-05   |   7.214e-03   |\n",
      "   44    |   4.505e-05   |   7.087e-03   |\n",
      "   45    |   3.786e-05   |   6.910e-03   |\n",
      "   46    |   3.806e-05   |   6.800e-03   |\n",
      "   47    |   4.634e-05   |   6.701e-03   |\n",
      "   48    |   8.135e-05   |   6.561e-03   |\n",
      "   49    |   5.257e-05   |   6.442e-03   |\n",
      "   50    |   6.807e-05   |   6.443e-03   |\n",
      "   51    |   4.624e-05   |   6.445e-03   |\n",
      "   52    |   5.634e-05   |   6.443e-03   |\n",
      "   53    |   6.258e-05   |   6.405e-03   |\n",
      "   54    |   5.198e-05   |   6.270e-03   |\n",
      "   55    |   6.261e-05   |   6.163e-03   |\n",
      "   56    |   3.679e-05   |   6.025e-03   |\n",
      "   57    |   6.231e-05   |   5.994e-03   |\n",
      "   58    |   2.597e-05   |   5.964e-03   |\n",
      "   59    |   7.422e-05   |   5.821e-03   |\n",
      "   60    |   3.689e-03   |   5.737e-03   |\n",
      "   61    |   4.866e-05   |   5.682e-03   |\n",
      "   62    |   2.811e-05   |   5.632e-03   |\n",
      "   63    |   3.425e-05   |   5.630e-03   |\n",
      "   64    |   3.407e-05   |   5.535e-03   |\n",
      "   65    |   4.073e-05   |   5.536e-03   |\n",
      "   66    |   1.729e-03   |   5.388e-03   |\n",
      "   67    |   3.439e-03   |   5.347e-03   |\n",
      "   68    |   3.310e-05   |   5.286e-03   |\n",
      "   69    |   2.943e-05   |   5.242e-03   |\n",
      "   70    |   3.829e-05   |   5.243e-03   |\n",
      "   71    |   3.200e-05   |   5.199e-03   |\n",
      "   72    |   2.361e-05   |   5.199e-03   |\n",
      "   73    |   1.637e-03   |   5.101e-03   |\n",
      "   74    |   2.882e-05   |   5.029e-03   |\n",
      "   75    |   2.770e-05   |   5.009e-03   |\n",
      "   76    |   3.996e-04   |   4.969e-03   |\n",
      "   77    |   1.018e-04   |   4.948e-03   |\n",
      "   78    |   2.750e-05   |   4.948e-03   |\n",
      "   79    |   2.255e-05   |   4.909e-03   |\n",
      "   80    |   2.218e-05   |   4.858e-03   |\n",
      "   81    |   1.951e-04   |   4.820e-03   |\n",
      "   82    |   2.275e-05   |   4.799e-03   |\n",
      "   83    |   2.980e-05   |   4.723e-03   |\n",
      "   84    |   1.842e-05   |   4.684e-03   |\n",
      "   85    |   3.270e-05   |   4.646e-03   |\n",
      "   86    |   2.528e-05   |   4.647e-03   |\n",
      "   87    |   2.441e-05   |   4.628e-03   |\n",
      "   88    |   2.912e-05   |   4.559e-03   |\n",
      "   89    |   9.312e-05   |   4.489e-03   |\n",
      "   90    |   3.521e-04   |   4.385e-03   |\n",
      "   91    |   3.209e-05   |   4.328e-03   |\n",
      "   92    |   2.583e-05   |   4.308e-03   |\n",
      "   93    |   2.610e-05   |   4.289e-03   |\n",
      "   94    |   1.502e-05   |   4.224e-03   |\n",
      "   95    |   1.344e-03   |   4.189e-03   |\n",
      "   96    |   3.274e-04   |   4.089e-03   |\n",
      "   97    |   2.281e-05   |   4.045e-03   |\n",
      "   98    |   1.887e-05   |   3.990e-03   |\n",
      "   99    |   1.722e-05   |   3.958e-03   |\n",
      "  100    |   7.848e-05   |   3.912e-03   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-EG):   Exceed the maximum number of epochs. Increase it to run further ...\n"
     ]
    }
   ],
   "source": [
    "file_name   = \"data/a9a.txt\"\n",
    "data_name   =  [\"a9a\"]\n",
    "my_verbose  = 1\n",
    "print('We are solving problem: ', file_name)\n",
    "my_data     = preprocess_real_data(file_name, m=10, noise_radius = 0.5, reg_par=1e-3)\n",
    "\n",
    "n, p        = my_data['n'], my_data['p']\n",
    "Lips        = my_data['Lips']\n",
    "my_prob4    = 1.0/(n**0.33)\n",
    "my_prob5    = 1.0/(n**0.33)\n",
    "my_alpha5   = 1 - my_prob5 \n",
    "x0          = 0.5*np.ones(p)\n",
    "\n",
    "scale_lr    = 50\n",
    "\n",
    "lr1         = scale_lr/Lips\n",
    "lr2         = scale_lr*0.5/Lips\n",
    "lr3         = scale_lr*0.5/Lips\n",
    "lr4         = scale_lr*0.95*(1 - np.sqrt(1-my_prob4))/(2.0*Lips)\n",
    "lr5         = scale_lr*0.95*np.sqrt(1-my_alpha5)/Lips\n",
    "lr6         = scale_lr*0.5/Lips \n",
    "\n",
    "all_output1, info1 = OneRun(my_data, x0, my_lr1=lr1, my_lr2=lr2, my_lr3=lr3, my_lr4=lr4, my_lr5=lr5, my_lr6=lr6)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f7c008b9-4941-45bd-a72d-26d7508241bf",
   "metadata": {},
   "source": [
    "## Run Experiment 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "85f67d8b-9b10-4f57-be7d-63cf792de5d6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "We are solving problem:  data/w8a.txt\n",
      "Data dimension: (n, p1, p2) = ( 45546 300 10 ) ...\n",
      "The Lipschitz constant:  80.72559636783001\n",
      "Problem size: n =  45546 , p =  311\n",
      "We are running the OG algorithm ...\n",
      " + The learning rate: eta =  1.2387644625670557\n",
      "Solver: Optimistic Gradient Method for Generalized Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   0     |   2.605e+00   |   1.000e+00   |\n",
      "   1     |   1.599e+00   |   1.443e-01   |\n",
      "   2     |   5.251e-01   |   1.821e-01   |\n",
      "   3     |   3.821e-01   |   1.709e-01   |\n",
      "   4     |   3.688e-01   |   1.625e-01   |\n",
      "   5     |   3.483e-01   |   1.539e-01   |\n",
      "   6     |   3.286e-01   |   1.454e-01   |\n",
      "   7     |   3.094e-01   |   1.370e-01   |\n",
      "   8     |   2.907e-01   |   1.289e-01   |\n",
      "   9     |   2.729e-01   |   1.210e-01   |\n",
      "   10    |   2.560e-01   |   1.134e-01   |\n",
      "   11    |   2.399e-01   |   1.062e-01   |\n",
      "   12    |   2.248e-01   |   9.935e-02   |\n",
      "   13    |   2.106e-01   |   9.290e-02   |\n",
      "   14    |   1.974e-01   |   8.677e-02   |\n",
      "   15    |   1.850e-01   |   8.109e-02   |\n",
      "   16    |   1.734e-01   |   7.580e-02   |\n",
      "   17    |   1.628e-01   |   7.088e-02   |\n",
      "   18    |   1.530e-01   |   6.631e-02   |\n",
      "   19    |   1.439e-01   |   6.208e-02   |\n",
      "   20    |   1.355e-01   |   5.815e-02   |\n",
      "   21    |   1.278e-01   |   5.450e-02   |\n",
      "   22    |   1.205e-01   |   5.115e-02   |\n",
      "   23    |   1.140e-01   |   4.807e-02   |\n",
      "   24    |   1.079e-01   |   4.521e-02   |\n",
      "   25    |   1.023e-01   |   4.255e-02   |\n",
      "   26    |   9.707e-02   |   4.012e-02   |\n",
      "   27    |   9.234e-02   |   3.784e-02   |\n",
      "   28    |   8.780e-02   |   3.574e-02   |\n",
      "   29    |   8.371e-02   |   3.383e-02   |\n",
      "   30    |   7.999e-02   |   3.206e-02   |\n",
      "   31    |   7.655e-02   |   3.042e-02   |\n",
      "   32    |   7.336e-02   |   2.891e-02   |\n",
      "   33    |   7.041e-02   |   2.750e-02   |\n",
      "   34    |   6.767e-02   |   2.619e-02   |\n",
      "   35    |   6.513e-02   |   2.498e-02   |\n",
      "   36    |   6.278e-02   |   2.385e-02   |\n",
      "   37    |   6.059e-02   |   2.279e-02   |\n",
      "   38    |   5.847e-02   |   2.181e-02   |\n",
      "   39    |   5.659e-02   |   2.090e-02   |\n",
      "   40    |   5.483e-02   |   2.006e-02   |\n",
      "   41    |   5.319e-02   |   1.927e-02   |\n",
      "   42    |   5.167e-02   |   1.854e-02   |\n",
      "   43    |   5.024e-02   |   1.785e-02   |\n",
      "   44    |   4.891e-02   |   1.721e-02   |\n",
      "   45    |   4.767e-02   |   1.662e-02   |\n",
      "   46    |   4.650e-02   |   1.606e-02   |\n",
      "   47    |   4.541e-02   |   1.553e-02   |\n",
      "   48    |   4.439e-02   |   1.504e-02   |\n",
      "   49    |   4.344e-02   |   1.458e-02   |\n",
      "   50    |   4.254e-02   |   1.414e-02   |\n",
      "   51    |   4.165e-02   |   1.373e-02   |\n",
      "   52    |   4.086e-02   |   1.335e-02   |\n",
      "   53    |   4.008e-02   |   1.298e-02   |\n",
      "   54    |   3.938e-02   |   1.265e-02   |\n",
      "   55    |   3.873e-02   |   1.234e-02   |\n",
      "   56    |   3.811e-02   |   1.205e-02   |\n",
      "   57    |   3.750e-02   |   1.175e-02   |\n",
      "   58    |   3.688e-02   |   1.149e-02   |\n",
      "   59    |   3.637e-02   |   1.124e-02   |\n",
      "   60    |   3.589e-02   |   1.102e-02   |\n",
      "   61    |   3.543e-02   |   1.080e-02   |\n",
      "   62    |   3.497e-02   |   1.059e-02   |\n",
      "   63    |   3.452e-02   |   1.039e-02   |\n",
      "   64    |   3.414e-02   |   1.021e-02   |\n",
      "   65    |   3.377e-02   |   1.004e-02   |\n",
      "   66    |   3.342e-02   |   9.883e-03   |\n",
      "   67    |   3.309e-02   |   9.732e-03   |\n",
      "   68    |   3.277e-02   |   9.590e-03   |\n",
      "   69    |   3.248e-02   |   9.455e-03   |\n",
      "   70    |   3.219e-02   |   9.328e-03   |\n",
      "   71    |   3.192e-02   |   9.207e-03   |\n",
      "   72    |   3.166e-02   |   9.093e-03   |\n",
      "   73    |   3.141e-02   |   8.985e-03   |\n",
      "   74    |   3.118e-02   |   8.883e-03   |\n",
      "   75    |   3.095e-02   |   8.786e-03   |\n",
      "   76    |   3.074e-02   |   8.694e-03   |\n",
      "   77    |   3.051e-02   |   8.602e-03   |\n",
      "   78    |   3.028e-02   |   8.514e-03   |\n",
      "   79    |   3.009e-02   |   8.435e-03   |\n",
      "   80    |   2.991e-02   |   8.358e-03   |\n",
      "   81    |   2.970e-02   |   8.275e-03   |\n",
      "   82    |   2.949e-02   |   8.196e-03   |\n",
      "   83    |   2.933e-02   |   8.128e-03   |\n",
      "   84    |   2.908e-02   |   8.050e-03   |\n",
      "   85    |   2.893e-02   |   7.991e-03   |\n",
      "   86    |   2.879e-02   |   7.935e-03   |\n",
      "   87    |   2.866e-02   |   7.882e-03   |\n",
      "   88    |   2.853e-02   |   7.831e-03   |\n",
      "   89    |   2.840e-02   |   7.782e-03   |\n",
      "   90    |   2.828e-02   |   7.736e-03   |\n",
      "   91    |   2.816e-02   |   7.691e-03   |\n",
      "   92    |   2.803e-02   |   7.639e-03   |\n",
      "   93    |   2.787e-02   |   7.591e-03   |\n",
      "   94    |   2.775e-02   |   7.549e-03   |\n",
      "   95    |   2.765e-02   |   7.510e-03   |\n",
      "   96    |   2.755e-02   |   7.473e-03   |\n",
      "   97    |   2.745e-02   |   7.436e-03   |\n",
      "   98    |   2.732e-02   |   7.396e-03   |\n",
      "   99    |   2.718e-02   |   7.337e-03   |\n",
      "========================================== \n",
      "\n",
      "Solver status (OG):      Exceed the maximum number of epochs. Increase it to run further ...\n",
      "We are running the double-loop SVR-FR algorithm ...\n",
      " + The learning rate: eta =  0.6193822312835279\n",
      "Solver: SVRG-Forward-Reflected Method for Generalized Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   0     |   4.831e+00   |   1.000e+00   |\n",
      "   1     |   1.581e+00   |   7.238e-02   |\n",
      "   2     |   1.075e+00   |   3.739e-02   |\n",
      "   3     |   5.965e-01   |   1.765e-02   |\n",
      "   4     |   4.367e-01   |   1.135e-02   |\n",
      "   5     |   3.673e-01   |   8.831e-03   |\n",
      "   6     |   3.323e-01   |   7.694e-03   |\n",
      "   7     |   3.096e-01   |   7.073e-03   |\n",
      "   8     |   2.929e-01   |   6.628e-03   |\n",
      "   9     |   2.791e-01   |   6.287e-03   |\n",
      "   10    |   2.638e-01   |   6.000e-03   |\n",
      "   11    |   2.460e-01   |   5.615e-03   |\n",
      "   12    |   2.257e-01   |   5.194e-03   |\n",
      "   13    |   2.065e-01   |   4.748e-03   |\n",
      "   14    |   1.865e-01   |   4.346e-03   |\n",
      "   15    |   1.665e-01   |   3.892e-03   |\n",
      "   16    |   1.456e-01   |   3.448e-03   |\n",
      "   17    |   1.291e-01   |   3.019e-03   |\n",
      "   18    |   1.108e-01   |   2.633e-03   |\n",
      "   19    |   9.295e-02   |   2.246e-03   |\n",
      "   20    |   7.693e-02   |   1.875e-03   |\n",
      "   21    |   6.491e-02   |   1.546e-03   |\n",
      "   22    |   5.261e-02   |   1.328e-03   |\n",
      "   23    |   4.328e-02   |   1.013e-03   |\n",
      "   24    |   3.634e-02   |   8.631e-04   |\n",
      "   25    |   2.925e-02   |   6.874e-04   |\n",
      "   26    |   2.400e-02   |   5.843e-04   |\n",
      "   27    |   1.966e-02   |   4.619e-04   |\n",
      "   28    |   1.697e-02   |   3.878e-04   |\n",
      "   29    |   1.443e-02   |   3.313e-04   |\n",
      "   30    |   1.310e-02   |   2.858e-04   |\n",
      "   31    |   1.138e-02   |   2.628e-04   |\n",
      "   32    |   9.873e-03   |   2.201e-04   |\n",
      "   33    |   8.929e-03   |   1.920e-04   |\n",
      "   34    |   8.292e-03   |   1.772e-04   |\n",
      "   35    |   7.267e-03   |   1.637e-04   |\n",
      "   36    |   6.468e-03   |   1.423e-04   |\n",
      "   37    |   5.923e-03   |   1.253e-04   |\n",
      "   38    |   5.532e-03   |   1.164e-04   |\n",
      "   39    |   5.175e-03   |   1.082e-04   |\n",
      "   40    |   4.844e-03   |   1.008e-04   |\n",
      "   41    |   4.543e-03   |   9.397e-05   |\n",
      "   42    |   4.268e-03   |   8.779e-05   |\n",
      "   43    |   4.016e-03   |   8.219e-05   |\n",
      "   44    |   3.787e-03   |   7.712e-05   |\n",
      "   45    |   3.336e-03   |   7.255e-05   |\n",
      "   46    |   3.018e-03   |   6.312e-05   |\n",
      "   47    |   2.885e-03   |   6.033e-05   |\n",
      "   48    |   2.764e-03   |   5.788e-05   |\n",
      "   49    |   2.661e-03   |   5.572e-05   |\n",
      "   50    |   2.568e-03   |   5.385e-05   |\n",
      "   51    |   2.478e-03   |   5.223e-05   |\n",
      "   52    |   2.405e-03   |   5.084e-05   |\n",
      "   53    |   2.323e-03   |   4.963e-05   |\n",
      "   54    |   2.261e-03   |   4.814e-05   |\n",
      "   55    |   2.207e-03   |   4.727e-05   |\n",
      "   56    |   2.161e-03   |   4.653e-05   |\n",
      "   57    |   2.123e-03   |   4.590e-05   |\n",
      "   58    |   2.085e-03   |   4.538e-05   |\n",
      "   59    |   2.054e-03   |   4.494e-05   |\n",
      "   60    |   2.023e-03   |   4.458e-05   |\n",
      "   61    |   2.001e-03   |   4.428e-05   |\n",
      "   62    |   1.978e-03   |   4.403e-05   |\n",
      "   63    |   1.953e-03   |   4.383e-05   |\n",
      "   64    |   1.940e-03   |   4.366e-05   |\n",
      "   65    |   1.923e-03   |   4.353e-05   |\n",
      "   66    |   1.911e-03   |   4.341e-05   |\n",
      "   67    |   1.896e-03   |   4.332e-05   |\n",
      "   68    |   1.885e-03   |   4.324e-05   |\n",
      "   69    |   1.874e-03   |   4.317e-05   |\n",
      "   70    |   1.862e-03   |   4.311e-05   |\n",
      "   71    |   1.857e-03   |   4.306e-05   |\n",
      "   72    |   1.849e-03   |   4.302e-05   |\n",
      "   73    |   1.841e-03   |   4.298e-05   |\n",
      "   74    |   1.831e-03   |   4.294e-05   |\n",
      "   75    |   1.824e-03   |   4.291e-05   |\n",
      "   76    |   1.819e-03   |   4.287e-05   |\n",
      "   77    |   1.814e-03   |   4.284e-05   |\n",
      "   78    |   1.807e-03   |   4.281e-05   |\n",
      "   79    |   1.803e-03   |   4.277e-05   |\n",
      "   80    |   1.797e-03   |   4.273e-05   |\n",
      "   81    |   1.795e-03   |   4.269e-05   |\n",
      "   82    |   1.784e-03   |   4.265e-05   |\n",
      "   83    |   1.783e-03   |   4.261e-05   |\n",
      "   84    |   1.780e-03   |   4.257e-05   |\n",
      "   85    |   1.768e-03   |   4.252e-05   |\n",
      "   86    |   1.768e-03   |   4.248e-05   |\n",
      "   87    |   1.762e-03   |   4.243e-05   |\n",
      "   88    |   1.759e-03   |   4.238e-05   |\n",
      "   89    |   1.754e-03   |   4.233e-05   |\n",
      "   90    |   1.749e-03   |   4.228e-05   |\n",
      "   91    |   1.745e-03   |   4.223e-05   |\n",
      "   92    |   1.740e-03   |   4.217e-05   |\n",
      "   93    |   1.737e-03   |   4.211e-05   |\n",
      "   94    |   1.731e-03   |   4.206e-05   |\n",
      "   95    |   1.724e-03   |   4.200e-05   |\n",
      "   96    |   1.724e-03   |   4.194e-05   |\n",
      "   97    |   1.715e-03   |   4.187e-05   |\n",
      "   98    |   1.712e-03   |   4.181e-05   |\n",
      "   99    |   1.707e-03   |   4.174e-05   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-FR):   Exceed the maximum number of epochs. Increase it to run further ...\n",
      "We are running the loopless SVRG-FR algorithm ...\n",
      " + The learning rate: eta =  0.6193822312835279\n",
      "Solver: Loopless-SVRG-Forward-Reflected Method for Generalized Equations ...\n",
      "========================================== \n",
      "  Epoch  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   1     |   1.388e+00   |   5.336e-01   |\n",
      "   2     |   4.499e-02   |   1.935e-02   |\n",
      "   3     |   1.724e-02   |   9.238e-03   |\n",
      "   4     |   9.360e-03   |   6.536e-03   |\n",
      "   5     |   6.706e-03   |   5.620e-03   |\n",
      "   6     |   5.510e-03   |   5.163e-03   |\n",
      "   7     |   5.073e-03   |   4.931e-03   |\n",
      "   8     |   4.610e-03   |   4.761e-03   |\n",
      "   9     |   4.385e-03   |   4.633e-03   |\n",
      "   10    |   4.190e-03   |   4.519e-03   |\n",
      "   11    |   4.017e-03   |   4.417e-03   |\n",
      "   12    |   3.819e-03   |   4.291e-03   |\n",
      "   13    |   3.623e-03   |   4.137e-03   |\n",
      "   14    |   3.330e-03   |   3.939e-03   |\n",
      "   15    |   3.117e-03   |   3.782e-03   |\n",
      "   16    |   2.805e-03   |   3.560e-03   |\n",
      "   17    |   2.487e-03   |   3.296e-03   |\n",
      "   18    |   2.219e-03   |   3.059e-03   |\n",
      "   19    |   1.975e-03   |   2.891e-03   |\n",
      "   20    |   1.764e-03   |   2.729e-03   |\n",
      "   21    |   1.467e-03   |   2.413e-03   |\n",
      "   22    |   1.241e-03   |   2.195e-03   |\n",
      "   23    |   1.046e-03   |   1.981e-03   |\n",
      "   24    |   8.310e-04   |   1.676e-03   |\n",
      "   25    |   7.125e-04   |   1.569e-03   |\n",
      "   26    |   6.014e-04   |   1.415e-03   |\n",
      "   27    |   4.783e-04   |   1.232e-03   |\n",
      "   28    |   4.107e-04   |   1.134e-03   |\n",
      "   29    |   3.556e-04   |   1.065e-03   |\n",
      "   30    |   2.869e-04   |   9.299e-04   |\n",
      "   31    |   2.474e-04   |   8.768e-04   |\n",
      "   32    |   2.190e-04   |   8.454e-04   |\n",
      "   33    |   1.943e-04   |   8.160e-04   |\n",
      "   34    |   1.801e-04   |   8.112e-04   |\n",
      "   35    |   1.503e-04   |   7.569e-04   |\n",
      "   36    |   1.345e-04   |   7.279e-04   |\n",
      "   37    |   1.193e-04   |   6.994e-04   |\n",
      "   38    |   1.110e-04   |   6.970e-04   |\n",
      "   39    |   1.032e-04   |   6.949e-04   |\n",
      "   40    |   9.083e-05   |   6.661e-04   |\n",
      "   41    |   8.047e-05   |   6.371e-04   |\n",
      "   42    |   7.568e-05   |   6.356e-04   |\n",
      "   43    |   7.036e-05   |   6.348e-04   |\n",
      "   44    |   6.625e-05   |   6.333e-04   |\n",
      "   45    |   6.223e-05   |   6.321e-04   |\n",
      "   46    |   5.837e-05   |   6.312e-04   |\n",
      "   47    |   5.230e-05   |   6.026e-04   |\n",
      "   48    |   4.961e-05   |   6.015e-04   |\n",
      "   49    |   4.694e-05   |   6.012e-04   |\n",
      "   50    |   4.486e-05   |   6.007e-04   |\n",
      "   51    |   4.268e-05   |   6.004e-04   |\n",
      "   52    |   4.077e-05   |   5.806e-04   |\n",
      "   53    |   3.728e-05   |   5.702e-04   |\n",
      "   54    |   3.646e-05   |   5.695e-04   |\n",
      "   55    |   3.484e-05   |   5.697e-04   |\n",
      "   56    |   3.387e-05   |   5.694e-04   |\n",
      "   57    |   3.297e-05   |   5.690e-04   |\n",
      "   58    |   3.220e-05   |   5.688e-04   |\n",
      "   59    |   3.171e-05   |   5.681e-04   |\n",
      "   60    |   3.108e-05   |   5.681e-04   |\n",
      "   61    |   3.066e-05   |   5.685e-04   |\n",
      "   62    |   2.947e-05   |   5.680e-04   |\n",
      "   63    |   2.905e-05   |   5.678e-04   |\n",
      "   64    |   2.868e-05   |   5.676e-04   |\n",
      "   65    |   2.852e-05   |   5.678e-04   |\n",
      "   66    |   2.808e-05   |   5.674e-04   |\n",
      "   67    |   2.811e-05   |   5.668e-04   |\n",
      "   68    |   2.816e-05   |   5.678e-04   |\n",
      "   69    |   2.734e-05   |   5.670e-04   |\n",
      "   70    |   2.719e-05   |   5.667e-04   |\n",
      "   71    |   2.698e-05   |   5.666e-04   |\n",
      "   72    |   2.721e-05   |   5.659e-04   |\n",
      "   73    |   2.669e-05   |   5.665e-04   |\n",
      "   74    |   2.655e-05   |   5.665e-04   |\n",
      "   75    |   2.643e-05   |   5.665e-04   |\n",
      "   76    |   2.633e-05   |   5.664e-04   |\n",
      "   77    |   2.636e-05   |   5.668e-04   |\n",
      "   78    |   2.620e-05   |   5.663e-04   |\n",
      "   79    |   2.603e-05   |   5.661e-04   |\n",
      "   80    |   2.595e-05   |   5.661e-04   |\n",
      "   81    |   2.593e-05   |   5.579e-04   |\n",
      "   82    |   2.579e-05   |   5.473e-04   |\n",
      "   83    |   2.572e-05   |   5.400e-04   |\n",
      "   84    |   2.569e-05   |   5.368e-04   |\n",
      "   85    |   2.553e-05   |   5.369e-04   |\n",
      "   86    |   2.565e-05   |   5.368e-04   |\n",
      "   87    |   2.540e-05   |   5.368e-04   |\n",
      "   88    |   2.548e-05   |   5.366e-04   |\n",
      "   89    |   2.534e-05   |   5.369e-04   |\n",
      "   90    |   2.525e-05   |   5.367e-04   |\n",
      "   91    |   2.532e-05   |   5.363e-04   |\n",
      "   92    |   2.552e-05   |   5.366e-04   |\n",
      "   93    |   2.516e-05   |   5.366e-04   |\n",
      "   94    |   2.504e-05   |   5.366e-04   |\n",
      "   95    |   2.500e-05   |   5.366e-04   |\n",
      "   96    |   2.499e-05   |   5.364e-04   |\n",
      "   97    |   2.523e-05   |   5.366e-04   |\n",
      "   98    |   2.486e-05   |   5.365e-04   |\n",
      "   99    |   2.480e-05   |   5.365e-04   |\n",
      "  100    |   2.476e-05   |   5.365e-04   |\n",
      "========================================== \n",
      "\n",
      "Solver status (LVR-FR):  Exceed the maximum number of epochs. Increase it to run further ...\n",
      "We are running the SAGA-FR algorithm ...\n",
      " + The learning rate: eta =  0.6193822312835279\n",
      "Solver: SAGA-Forward-Reflected Method for Generalized Equations ...\n",
      "========================================== \n",
      "  Iters  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   1     |   1.388e+00   |   5.336e-01   |\n",
      "   2     |   7.609e-02   |   3.075e-02   |\n",
      "   3     |   3.504e-02   |   1.469e-02   |\n",
      "   4     |   2.367e-02   |   1.061e-02   |\n",
      "   5     |   1.958e-02   |   9.008e-03   |\n",
      "   6     |   1.139e-02   |   6.145e-03   |\n",
      "   7     |   6.330e-03   |   5.219e-03   |\n",
      "   8     |   4.847e-03   |   4.829e-03   |\n",
      "   9     |   4.596e-03   |   4.652e-03   |\n",
      "   10    |   4.239e-03   |   4.537e-03   |\n",
      "   11    |   4.028e-03   |   4.412e-03   |\n",
      "   12    |   3.795e-03   |   4.262e-03   |\n",
      "   13    |   3.583e-03   |   4.144e-03   |\n",
      "   14    |   3.323e-03   |   3.943e-03   |\n",
      "   15    |   3.063e-03   |   3.736e-03   |\n",
      "   16    |   2.760e-03   |   3.492e-03   |\n",
      "   17    |   2.499e-03   |   3.304e-03   |\n",
      "   18    |   2.232e-03   |   3.066e-03   |\n",
      "   19    |   1.971e-03   |   2.868e-03   |\n",
      "   20    |   1.719e-03   |   2.658e-03   |\n",
      "   21    |   1.485e-03   |   2.425e-03   |\n",
      "   22    |   1.240e-03   |   2.171e-03   |\n",
      "   23    |   1.025e-03   |   1.920e-03   |\n",
      "   24    |   8.704e-04   |   1.766e-03   |\n",
      "   25    |   7.137e-04   |   1.560e-03   |\n",
      "   26    |   6.114e-04   |   1.437e-03   |\n",
      "   27    |   4.651e-04   |   1.162e-03   |\n",
      "   28    |   3.903e-04   |   1.074e-03   |\n",
      "   29    |   3.346e-04   |   1.021e-03   |\n",
      "   30    |   2.945e-04   |   9.709e-04   |\n",
      "   31    |   2.493e-04   |   8.747e-04   |\n",
      "   32    |   2.144e-04   |   8.419e-04   |\n",
      "   33    |   1.891e-04   |   7.907e-04   |\n",
      "   34    |   1.605e-04   |   7.608e-04   |\n",
      "   35    |   1.535e-04   |   7.568e-04   |\n",
      "   36    |   1.322e-04   |   7.119e-04   |\n",
      "   37    |   1.164e-04   |   6.987e-04   |\n",
      "   38    |   1.094e-04   |   6.964e-04   |\n",
      "   39    |   9.566e-05   |   6.677e-04   |\n",
      "   40    |   8.957e-05   |   6.656e-04   |\n",
      "   41    |   8.626e-05   |   6.628e-04   |\n",
      "   42    |   7.831e-05   |   6.616e-04   |\n",
      "   43    |   6.958e-05   |   6.342e-04   |\n",
      "   44    |   6.260e-05   |   6.043e-04   |\n",
      "   45    |   5.837e-05   |   6.028e-04   |\n",
      "   46    |   5.186e-05   |   5.735e-04   |\n",
      "   47    |   4.910e-05   |   5.730e-04   |\n",
      "   48    |   4.641e-05   |   5.734e-04   |\n",
      "   49    |   4.347e-05   |   5.720e-04   |\n",
      "   50    |   4.156e-05   |   5.715e-04   |\n",
      "   51    |   4.014e-05   |   5.709e-04   |\n",
      "   52    |   3.848e-05   |   5.708e-04   |\n",
      "   53    |   3.799e-05   |   5.705e-04   |\n",
      "   54    |   3.614e-05   |   5.694e-04   |\n",
      "   55    |   3.456e-05   |   5.697e-04   |\n",
      "   56    |   3.345e-05   |   5.695e-04   |\n",
      "   57    |   3.285e-05   |   5.690e-04   |\n",
      "   58    |   3.179e-05   |   5.690e-04   |\n",
      "   59    |   3.138e-05   |   5.686e-04   |\n",
      "   60    |   3.068e-05   |   5.683e-04   |\n",
      "   61    |   3.063e-05   |   5.688e-04   |\n",
      "   62    |   2.966e-05   |   5.684e-04   |\n",
      "   63    |   2.974e-05   |   5.676e-04   |\n",
      "   64    |   2.906e-05   |   5.669e-04   |\n",
      "   65    |   2.857e-05   |   5.666e-04   |\n",
      "   66    |   2.819e-05   |   5.669e-04   |\n",
      "   67    |   2.823e-05   |   5.670e-04   |\n",
      "   68    |   2.763e-05   |   5.674e-04   |\n",
      "   69    |   2.792e-05   |   5.667e-04   |\n",
      "   70    |   2.743e-05   |   5.674e-04   |\n",
      "   71    |   2.731e-05   |   5.663e-04   |\n",
      "   72    |   2.709e-05   |   5.666e-04   |\n",
      "   73    |   2.686e-05   |   5.660e-04   |\n",
      "   74    |   2.657e-05   |   5.665e-04   |\n",
      "   75    |   2.636e-05   |   5.668e-04   |\n",
      "   76    |   2.652e-05   |   5.542e-04   |\n",
      "   77    |   2.623e-05   |   5.444e-04   |\n",
      "   78    |   2.632e-05   |   5.386e-04   |\n",
      "   79    |   2.602e-05   |   5.374e-04   |\n",
      "   80    |   2.660e-05   |   5.368e-04   |\n",
      "   81    |   2.595e-05   |   5.365e-04   |\n",
      "   82    |   2.603e-05   |   5.364e-04   |\n",
      "   83    |   2.570e-05   |   5.369e-04   |\n",
      "   84    |   2.554e-05   |   5.365e-04   |\n",
      "   85    |   2.567e-05   |   5.366e-04   |\n",
      "   86    |   2.567e-05   |   5.362e-04   |\n",
      "   87    |   2.551e-05   |   5.369e-04   |\n",
      "   88    |   2.623e-05   |   5.371e-04   |\n",
      "   89    |   2.552e-05   |   5.378e-04   |\n",
      "   90    |   2.539e-05   |   5.362e-04   |\n",
      "   91    |   2.541e-05   |   5.369e-04   |\n",
      "   92    |   2.526e-05   |   5.373e-04   |\n",
      "   93    |   2.504e-05   |   5.365e-04   |\n",
      "   94    |   2.521e-05   |   5.367e-04   |\n",
      "   95    |   2.530e-05   |   5.367e-04   |\n",
      "   96    |   2.490e-05   |   5.365e-04   |\n",
      "   97    |   2.500e-05   |   5.372e-04   |\n",
      "   98    |   2.515e-05   |   5.357e-04   |\n",
      "   99    |   2.484e-05   |   5.370e-04   |\n",
      "  100    |   2.552e-05   |   5.377e-04   |\n",
      "========================================== \n",
      "\n",
      "Solver status (SAGA-FR): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "We are running the FRBS algorithm ...\n",
      " + The learning rate: eta =  0.008601011625517576\n",
      "Solver: Variance-Reduced Forward-Reflected-Backward Splitting (Alacaoglu et al 2021) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   1     |   1.265e+00   |   1.000e+00   |\n",
      "   2     |   1.845e-02   |   1.459e-02   |\n",
      "   3     |   6.940e-03   |   5.485e-03   |\n",
      "   4     |   6.460e-03   |   5.105e-03   |\n",
      "   5     |   6.314e-03   |   4.990e-03   |\n",
      "   6     |   6.173e-03   |   4.879e-03   |\n",
      "   7     |   5.764e-03   |   4.555e-03   |\n",
      "   8     |   5.506e-03   |   4.351e-03   |\n",
      "   9     |   5.299e-03   |   4.188e-03   |\n",
      "   10    |   5.067e-03   |   4.005e-03   |\n",
      "   11    |   4.841e-03   |   3.826e-03   |\n",
      "   12    |   3.966e-03   |   3.134e-03   |\n",
      "   13    |   4.406e-03   |   3.482e-03   |\n",
      "   14    |   3.989e-03   |   3.153e-03   |\n",
      "   15    |   3.924e-03   |   3.101e-03   |\n",
      "   16    |   3.675e-03   |   2.904e-03   |\n",
      "   17    |   3.454e-03   |   2.730e-03   |\n",
      "   18    |   2.778e-03   |   2.195e-03   |\n",
      "   19    |   2.989e-03   |   2.362e-03   |\n",
      "   20    |   2.826e-03   |   2.233e-03   |\n",
      "   21    |   2.653e-03   |   2.097e-03   |\n",
      "   22    |   2.454e-03   |   1.940e-03   |\n",
      "   23    |   2.252e-03   |   1.780e-03   |\n",
      "   24    |   2.196e-03   |   1.736e-03   |\n",
      "   25    |   2.060e-03   |   1.628e-03   |\n",
      "   26    |   1.795e-03   |   1.419e-03   |\n",
      "   27    |   1.840e-03   |   1.454e-03   |\n",
      "   28    |   1.764e-03   |   1.394e-03   |\n",
      "   29    |   1.673e-03   |   1.323e-03   |\n",
      "   30    |   1.552e-03   |   1.226e-03   |\n",
      "   31    |   1.468e-03   |   1.160e-03   |\n",
      "   32    |   1.414e-03   |   1.118e-03   |\n",
      "   33    |   1.341e-03   |   1.060e-03   |\n",
      "   34    |   1.254e-03   |   9.913e-04   |\n",
      "   35    |   1.190e-03   |   9.405e-04   |\n",
      "   36    |   1.132e-03   |   8.943e-04   |\n",
      "   37    |   1.096e-03   |   8.664e-04   |\n",
      "   38    |   1.044e-03   |   8.247e-04   |\n",
      "   39    |   9.904e-04   |   7.827e-04   |\n",
      "   40    |   9.527e-04   |   7.529e-04   |\n",
      "   41    |   9.054e-04   |   7.156e-04   |\n",
      "   42    |   8.729e-04   |   6.898e-04   |\n",
      "   43    |   8.002e-04   |   6.324e-04   |\n",
      "   44    |   8.076e-04   |   6.383e-04   |\n",
      "   45    |   7.703e-04   |   6.087e-04   |\n",
      "   46    |   7.469e-04   |   5.903e-04   |\n",
      "   47    |   7.140e-04   |   5.643e-04   |\n",
      "   48    |   6.915e-04   |   5.465e-04   |\n",
      "   49    |   6.664e-04   |   5.267e-04   |\n",
      "   50    |   6.460e-04   |   5.106e-04   |\n",
      "   51    |   6.244e-04   |   4.935e-04   |\n",
      "   52    |   6.034e-04   |   4.769e-04   |\n",
      "   53    |   5.859e-04   |   4.630e-04   |\n",
      "   54    |   5.740e-04   |   4.536e-04   |\n",
      "   55    |   5.568e-04   |   4.400e-04   |\n",
      "   56    |   5.435e-04   |   4.295e-04   |\n",
      "   57    |   5.236e-04   |   4.138e-04   |\n",
      "   58    |   4.985e-04   |   3.940e-04   |\n",
      "   59    |   5.017e-04   |   3.965e-04   |\n",
      "   60    |   4.918e-04   |   3.887e-04   |\n",
      "   61    |   4.744e-04   |   3.749e-04   |\n",
      "   62    |   4.695e-04   |   3.710e-04   |\n",
      "   63    |   4.572e-04   |   3.613e-04   |\n",
      "   64    |   4.450e-04   |   3.517e-04   |\n",
      "   65    |   4.375e-04   |   3.458e-04   |\n",
      "   66    |   4.300e-04   |   3.399e-04   |\n",
      "   67    |   4.219e-04   |   3.335e-04   |\n",
      "   68    |   4.145e-04   |   3.276e-04   |\n",
      "   69    |   4.085e-04   |   3.228e-04   |\n",
      "   70    |   3.831e-04   |   3.028e-04   |\n",
      "   71    |   3.933e-04   |   3.109e-04   |\n",
      "   72    |   3.868e-04   |   3.057e-04   |\n",
      "   73    |   3.828e-04   |   3.026e-04   |\n",
      "   74    |   3.758e-04   |   2.970e-04   |\n",
      "   75    |   3.701e-04   |   2.925e-04   |\n",
      "   76    |   3.641e-04   |   2.878e-04   |\n",
      "   77    |   3.589e-04   |   2.837e-04   |\n",
      "   78    |   3.562e-04   |   2.815e-04   |\n",
      "   79    |   3.488e-04   |   2.756e-04   |\n",
      "   80    |   3.469e-04   |   2.742e-04   |\n",
      "   81    |   3.397e-04   |   2.684e-04   |\n",
      "   82    |   3.387e-04   |   2.677e-04   |\n",
      "   83    |   3.350e-04   |   2.648e-04   |\n",
      "   84    |   3.321e-04   |   2.625e-04   |\n",
      "   85    |   3.283e-04   |   2.595e-04   |\n",
      "   86    |   3.240e-04   |   2.560e-04   |\n",
      "   87    |   3.169e-04   |   2.505e-04   |\n",
      "   88    |   3.169e-04   |   2.505e-04   |\n",
      "   89    |   3.153e-04   |   2.492e-04   |\n",
      "   90    |   3.133e-04   |   2.476e-04   |\n",
      "   91    |   3.104e-04   |   2.453e-04   |\n",
      "   92    |   3.077e-04   |   2.432e-04   |\n",
      "   93    |   3.055e-04   |   2.414e-04   |\n",
      "   94    |   3.035e-04   |   2.399e-04   |\n",
      "   95    |   3.012e-04   |   2.380e-04   |\n",
      "   96    |   2.993e-04   |   2.366e-04   |\n",
      "   97    |   2.974e-04   |   2.351e-04   |\n",
      "   98    |   2.944e-04   |   2.327e-04   |\n",
      "   99    |   2.910e-04   |   2.300e-04   |\n",
      "  100    |   2.903e-04   |   2.294e-04   |\n",
      "========================================== \n",
      "\n",
      "Solver status (VR-FRBS): Exceed the maximum number of epochs. Increase it to run further ...\n",
      "We are running the SVRG-EG algorithm ...\n",
      " + The learning rate: eta =  1.2387644625670557\n",
      "Solver: Variance-Reduced Extragradient Method (Alacaoglu & Malitsky 2022) ...\n",
      "========================================== \n",
      "  Epoch  |     Error     | ||G_eta(x)||  \n",
      " ------------------------------------------\n",
      "   1     |   1.275e+00   |   8.713e-01   |\n",
      "   2     |   3.626e-03   |   9.607e-02   |\n",
      "   3     |   4.374e-03   |   9.332e-02   |\n",
      "   4     |   5.304e-03   |   9.054e-02   |\n",
      "   5     |   3.503e-03   |   8.461e-02   |\n",
      "   6     |   2.283e-03   |   7.880e-02   |\n",
      "   7     |   3.370e-03   |   7.886e-02   |\n",
      "   8     |   3.308e-03   |   7.328e-02   |\n",
      "   9     |   1.874e-03   |   7.331e-02   |\n",
      "   10    |   3.235e-03   |   7.043e-02   |\n",
      "   11    |   3.575e-03   |   6.247e-02   |\n",
      "   12    |   2.425e-03   |   5.294e-02   |\n",
      "   13    |   1.650e-03   |   5.073e-02   |\n",
      "   14    |   1.519e-03   |   4.318e-02   |\n",
      "   15    |   1.152e-03   |   3.960e-02   |\n",
      "   16    |   8.324e-04   |   3.798e-02   |\n",
      "   17    |   1.110e-03   |   3.492e-02   |\n",
      "   18    |   1.066e-03   |   3.251e-02   |\n",
      "   19    |   7.067e-04   |   2.882e-02   |\n",
      "   20    |   1.070e-03   |   2.564e-02   |\n",
      "   21    |   4.552e-04   |   2.470e-02   |\n",
      "   22    |   7.544e-04   |   2.294e-02   |\n",
      "   23    |   4.653e-04   |   2.214e-02   |\n",
      "   24    |   6.423e-04   |   2.212e-02   |\n",
      "   25    |   7.126e-04   |   2.134e-02   |\n",
      "   26    |   4.982e-04   |   1.987e-02   |\n",
      "   27    |   4.224e-04   |   1.803e-02   |\n",
      "   28    |   3.538e-04   |   1.636e-02   |\n",
      "   29    |   1.126e-02   |   1.550e-02   |\n",
      "   30    |   4.134e-04   |   1.452e-02   |\n",
      "   31    |   2.008e-04   |   1.409e-02   |\n",
      "   32    |   1.952e-04   |   1.242e-02   |\n",
      "   33    |   1.550e-04   |   1.242e-02   |\n",
      "   34    |   1.581e-04   |   1.181e-02   |\n",
      "   35    |   1.886e-04   |   1.098e-02   |\n",
      "   36    |   2.398e-04   |   1.101e-02   |\n",
      "   37    |   1.822e-04   |   1.054e-02   |\n",
      "   38    |   2.244e-04   |   1.007e-02   |\n",
      "   39    |   1.707e-03   |   9.476e-03   |\n",
      "   40    |   1.028e-04   |   9.275e-03   |\n",
      "   41    |   6.524e-03   |   8.963e-03   |\n",
      "   42    |   9.605e-05   |   8.454e-03   |\n",
      "   43    |   1.478e-03   |   8.177e-03   |\n",
      "   44    |   1.355e-04   |   8.159e-03   |\n",
      "   45    |   1.034e-04   |   7.776e-03   |\n",
      "   46    |   9.809e-05   |   7.654e-03   |\n",
      "   47    |   7.862e-05   |   7.161e-03   |\n",
      "   48    |   6.888e-05   |   7.162e-03   |\n",
      "   49    |   8.308e-05   |   6.968e-03   |\n",
      "   50    |   8.173e-05   |   6.971e-03   |\n",
      "   51    |   9.730e-05   |   6.960e-03   |\n",
      "   52    |   7.404e-05   |   6.798e-03   |\n",
      "   53    |   9.757e-03   |   6.668e-03   |\n",
      "   54    |   1.152e-04   |   6.396e-03   |\n",
      "   55    |   9.521e-05   |   6.320e-03   |\n",
      "   56    |   7.567e-05   |   6.254e-03   |\n",
      "   57    |   8.591e-05   |   6.181e-03   |\n",
      "   58    |   5.793e-05   |   6.064e-03   |\n",
      "   59    |   6.489e-05   |   5.994e-03   |\n",
      "   60    |   1.670e-04   |   5.884e-03   |\n",
      "   61    |   5.304e-04   |   5.823e-03   |\n",
      "   62    |   7.681e-05   |   5.714e-03   |\n",
      "   63    |   5.889e-05   |   5.668e-03   |\n",
      "   64    |   6.579e-05   |   5.570e-03   |\n",
      "   65    |   5.307e-05   |   5.336e-03   |\n",
      "   66    |   6.161e-05   |   5.263e-03   |\n",
      "   67    |   7.561e-03   |   5.167e-03   |\n",
      "   68    |   1.843e-03   |   5.061e-03   |\n",
      "   69    |   6.336e-05   |   5.037e-03   |\n",
      "   70    |   5.312e-05   |   5.032e-03   |\n",
      "   71    |   3.713e-05   |   4.976e-03   |\n",
      "   72    |   4.141e-05   |   4.923e-03   |\n",
      "   73    |   8.726e-04   |   4.802e-03   |\n",
      "   74    |   4.043e-05   |   4.758e-03   |\n",
      "   75    |   3.824e-05   |   4.735e-03   |\n",
      "   76    |   3.651e-05   |   4.677e-03   |\n",
      "   77    |   8.410e-04   |   4.610e-03   |\n",
      "   78    |   6.619e-03   |   4.523e-03   |\n",
      "   79    |   2.924e-05   |   4.515e-03   |\n",
      "   80    |   3.501e-05   |   4.484e-03   |\n",
      "   81    |   3.488e-05   |   4.469e-03   |\n",
      "   82    |   3.365e-05   |   4.440e-03   |\n",
      "   83    |   1.617e-03   |   4.428e-03   |\n",
      "   84    |   3.387e-05   |   4.413e-03   |\n",
      "   85    |   2.809e-05   |   4.396e-03   |\n",
      "   86    |   4.280e-05   |   4.372e-03   |\n",
      "   87    |   2.204e-05   |   4.346e-03   |\n",
      "   88    |   3.295e-05   |   4.323e-03   |\n",
      "   89    |   3.170e-05   |   4.277e-03   |\n",
      "   90    |   7.683e-04   |   4.221e-03   |\n",
      "   91    |   1.528e-03   |   4.184e-03   |\n",
      "   92    |   6.103e-03   |   4.171e-03   |\n",
      "   93    |   3.959e-05   |   4.159e-03   |\n",
      "   94    |   3.773e-04   |   4.131e-03   |\n",
      "   95    |   2.123e-05   |   4.101e-03   |\n"
     ]
    }
   ],
   "source": [
    "file_name    = \"data/w8a.txt\"\n",
    "data_name.append(\"w8a\")\n",
    "my_verbose   = 1\n",
    "print('We are solving problem: ', file_name)\n",
    "my_data     = preprocess_real_data(file_name, m=10, noise_radius = 0.5, reg_par=1e-3)\n",
    "\n",
    "n, p        = my_data['n'], my_data['p']\n",
    "Lips        = my_data['Lips']\n",
    "my_prob4    = 1.0/(n**0.33)\n",
    "my_prob5    = 1.0/(n**0.33)\n",
    "my_alpha5   = 1 - my_prob5 \n",
    "x0          = 0.5*np.ones(p)\n",
    "\n",
    "scale_lr    = 100\n",
    "\n",
    "lr1         = scale_lr*1.0/Lips\n",
    "lr2         = scale_lr*0.5/Lips\n",
    "lr3         = scale_lr*0.5/Lips\n",
    "lr4         = scale_lr*0.95*(1 - np.sqrt(1-my_prob4))/(2.0*Lips)\n",
    "lr5         = scale_lr*0.95*np.sqrt(1-my_alpha5)/Lips\n",
    "lr6         = scale_lr*0.5/Lips \n",
    "\n",
    "all_output2, info2 = OneRun(my_data, x0, my_lr1=lr1, my_lr2=lr2, my_lr3=lr3, my_lr4=lr4, my_lr5=lr5, my_lr6=lr6)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3b8f1b0b-1e03-42c4-9bf3-f1610c83dc10",
   "metadata": {},
   "source": [
    "## Plot The Results of The Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "af9689b8-36e6-474b-af3f-8ee532413290",
   "metadata": {},
   "outputs": [],
   "source": [
    "## Number of methods\n",
    "hist, it_plt, op_norm1, op_norm2 = [], [], [], []\n",
    "for i in range(len(all_output1)):\n",
    "    hist1   = all_output1[i].get(\"epoch_hist\")\n",
    "    hist2   = all_output2[i].get(\"epoch_hist\")\n",
    "    it_plt.append( [h.get(\"epoch\") for h in hist1] )\n",
    "    op_norm1.append( [h.get(\"op_norm\") for h in hist1] )\n",
    "    op_norm2.append( [h.get(\"op_norm\") for h in hist2] )\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9ddd28fc-3fd8-4b13-bb99-9cdfff6e2f2d",
   "metadata": {},
   "outputs": [],
   "source": [
    "## This is for plottings\n",
    "alg_name = ['OG','VFR-svrg', 'LVFR-svrg', 'VFR-saga', 'VFRBS', 'VEG'] \n",
    "colors   = ['b', 'r', 'g', 'm', 'y', 'k']\n",
    "line_styles = ['-.', '--', '-', '-.', '--', '-']\n",
    "my_markers = ['o', '*', 'd', 's', '>', 'x']\n",
    "n1, p1, m1 = info1['n'], info1['p'], 10\n",
    "n2, p2, m2 = info2['n'], info2['p'], 10\n",
    "\n",
    "\n",
    "## Now we plot the results.\n",
    "fig, axs = plt.subplots(1, 2, figsize=(12, 3.5))\n",
    "for i in range(len(all_output1)):\n",
    "    axs[0].semilogy(it_plt[i], op_norm1[i], color=colors[i], linestyle=line_styles[i],\\\n",
    "                    marker = my_markers[i], markersize=4, markevery=5, label=alg_name[i])\n",
    "    axs[1].semilogy(it_plt[i], op_norm2[i], color=colors[i], linestyle=line_styles[i],\\\n",
    "                    marker = my_markers[i], markersize=4, markevery=5, label=alg_name[i])\n",
    "    \n",
    "axs[0].legend(loc='upper right')\n",
    "axs[0].grid(True)\n",
    "axs[0].set_title('The ' + data_name[0] + ' Dataset: (n, p, m) = (' + str(n1) + ', ' + str(p1) + ', ' + str(m1) + ')', fontsize=11)\n",
    "axs[0].set_xlabel('Number of epochs')\n",
    "axs[0].set_ylabel('Relative operator norm $\\Vert \\mathcal{G}_{\\\\eta}x^k\\Vert/\\Vert \\mathcal{G}_{\\\\eta}x^0\\Vert$')\n",
    "\n",
    "axs[1].legend(loc='upper right')\n",
    "axs[1].grid(True)\n",
    "axs[1].set_title('The ' + data_name[1] + ' Dataset: (n, p, m) = (' + str(n2) + ', ' + str(p2) + ', ' + str(m2) + ')', fontsize=11)\n",
    "axs[1].set_xlabel('Number of epochs')\n",
    "axs[1].set_ylabel('Relative operator norm $\\Vert \\mathcal{G}_{\\\\eta}x^k\\Vert/\\Vert \\mathcal{G}_{\\\\eta}x^0\\Vert$')\n",
    "\n",
    "plt.show()\n",
    "fig.savefig(\"figs/logistic_reg_exam2.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d4bdc82f-5a98-4460-b957-2b15ad6a82ae",
   "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
}
