{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "2Z5Cq8aRXqi0"
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from numpy import linalg as LA\n",
    "import time\n",
    "\n",
    "def construct_A(m):\n",
    "    A = np.zeros((m,m))\n",
    "    for i in range(m):\n",
    "        j = m-1-i\n",
    "        if (j > i):\n",
    "           A[i][j] = -1\n",
    "        else:\n",
    "           A[i][j] = 1\n",
    "    return A\n",
    "\n",
    "def RG(m, eps, eta): # m = #dimension, eps = error, eta = step-size\n",
    "    A = construct_A(m)\n",
    "    x_0 = y_0 = np.ones(m)\n",
    "    old_x = x_0\n",
    "    old_y = y_0\n",
    "    iters = 1\n",
    "    tic = time.perf_counter() #start counting time\n",
    "    new_x = old_x - eta*np.dot(A, old_y)\n",
    "    residual =  LA.norm(new_x - old_y)/eta + LA.norm(old_x - old_y)/eta\n",
    "    while(iters < 1000 and residual > eps):\n",
    "        new_y = 2*new_x - old_x\n",
    "        old_x = new_x\n",
    "        old_y = new_y\n",
    "        new_x = old_x - eta*np.dot(A, old_y)\n",
    "        residual =  LA.norm(new_x - old_y)/eta + LA.norm(old_x - old_y)/eta\n",
    "        iters = iters + 1\n",
    "    toc = time.perf_counter() #stop counting time\n",
    "    return iters, residual, toc-tic\n",
    "\n",
    "def EG(m, eps, eta): # m = #dimension, eps = error, eta = step-size\n",
    "    A = construct_A(m)\n",
    "    x_0 = np.ones(m)\n",
    "    old_x = x_0\n",
    "    iters = 1\n",
    "    tic = time.perf_counter() #start counting time\n",
    "    y = old_x - eta*np.dot(A, old_x)\n",
    "    residual =  LA.norm(old_x - y)/eta\n",
    "    while(iters < 1000 and residual > eps):\n",
    "        new_x = old_x - eta*np.dot(A, y)\n",
    "        old_x = new_x\n",
    "        y = old_x - eta*np.dot(A, old_x)\n",
    "        residual =  LA.norm(old_x - y)/eta\n",
    "        iters = iters + 1\n",
    "    toc = time.perf_counter() #stop counting time\n",
    "    return iters, residual, toc-tic\n",
    "\n",
    "\n",
    "def ARG(m, eps, eta, max_iters): # m = #dimension, eps = error, eta = step-size\n",
    "    A = construct_A(m)\n",
    "    x_0 = np.ones(m)\n",
    "    old_x = x_0\n",
    "    y = x_0\n",
    "    iters = 1\n",
    "    tic = time.perf_counter() #start counting time\n",
    "    gradient = np.dot(A, y)\n",
    "    new_x = old_x - eta*gradient \n",
    "    residual =  residual =  LA.norm(gradient)\n",
    "    while(iters < max_iters and residual > eps):\n",
    "        y = 2*new_x - old_x  + 1/(iters+1)*(x_0 - new_x) - 1/iters*(x_0 - old_x)\n",
    "        old_x = new_x\n",
    "        gradient = np.dot(A, y)\n",
    "        new_x = old_x - eta*gradient + 1/(iters+1)*(x_0 - old_x)\n",
    "        residual =  LA.norm(gradient)\n",
    "        iters = iters + 1\n",
    "    toc = time.perf_counter() #stop counting time\n",
    "    return iters, residual, toc-tic\n",
    "\n",
    "def FEG_AS(m, eps, eta, max_iters): # m = #dimension, eps = error, eta = step-size\n",
    "    A = construct_A(m)\n",
    "    x_0 = np.ones(m)\n",
    "    old_x = x_0\n",
    "    y = x_0\n",
    "    iters = 1\n",
    "    tic = time.perf_counter() #start counting time\n",
    "    gradient = np.dot(A, old_x)\n",
    "    residual =  LA.norm(gradient)\n",
    "    while(iters < max_iters and residual > eps):\n",
    "        new_x = old_x - iters/(iters+1)*eta*np.dot(A, y) + 1/(iters+1)*(x_0 - old_x)\n",
    "        old_x = new_x\n",
    "        gradient = np.dot(A, old_x)\n",
    "        y = old_x - eta*gradient + 1/(iters+2)*(x_0 - old_x)\n",
    "        residual =  LA.norm(gradient)\n",
    "        iters = iters + 1\n",
    "    toc = time.perf_counter() #stop counting time\n",
    "    return iters, residual, toc-tic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "X38fgdIPgbLf",
    "outputId": "b873aa9f-23e2-46f7-a10d-d232f09d6677",
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.00919104 0.02052083 0.01035925 0.00835938 0.00909846 0.01124942\n",
      " 0.01336937 0.01755433 0.01767796 0.02784275 0.05857729 0.05314175\n",
      " 0.05779558 0.06419517 0.07911333 0.11484142 0.1301365  0.144439\n",
      " 0.191225   0.22381825 0.25292425 0.26455975 0.23987333 0.27096558\n",
      " 0.29327612 0.30647217 0.33139562 0.355855   0.38790229 0.50170892\n",
      " 0.53605554 0.54585413 0.61943333 0.63742604 0.68299979 0.70455008\n",
      " 0.66022412 0.65948837 0.69944342 0.72440921 0.80269846 0.82295979\n",
      " 0.86382542 0.89224896 1.00966779 0.98296542 1.03765954 1.13899254\n",
      " 1.13827337 1.16498608 1.21258675 1.305197   1.36076925 1.41490254\n",
      " 1.46269254 1.51514883 1.64462683 1.67092425 1.68493283 1.71466217\n",
      " 1.76667683 1.81977008 1.8991845  1.971193   1.99975392 2.05793321\n",
      " 2.12323496 2.20073742 2.24480029 2.38955571 2.43134858 2.54738808\n",
      " 2.56262642 2.66380387 2.72528613 2.77130646 2.81892446 3.06681396\n",
      " 3.033376   3.29043883]\n",
      "[129. 134. 137. 139. 140. 142. 143. 144. 144. 145. 146. 146. 147. 147.\n",
      " 148. 148. 149. 149. 150. 150. 150. 151. 151. 151. 151. 152. 152. 152.\n",
      " 152. 153. 153. 153. 153. 154. 154. 154. 154. 154. 155. 155. 155. 155.\n",
      " 155. 155. 156. 156. 156. 156. 156. 156. 156. 157. 157. 157. 157. 157.\n",
      " 157. 157. 157. 157. 158. 158. 158. 158. 158. 158. 158. 158. 158. 159.\n",
      " 159. 159. 159. 159. 159. 159. 159. 159. 159. 159.]\n"
     ]
    }
   ],
   "source": [
    "dim = 2000\n",
    "test_num = 80\n",
    "\n",
    "time_EG = np.ones(test_num)\n",
    "iter_EG = np.ones(test_num)\n",
    "for i in range(test_num):\n",
    "    iter_EG[i], c, time_EG[i] = EG(100*(i+1),0.001,0.4)\n",
    "print(time_EG)\n",
    "print(iter_EG)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.007879   0.00865842 0.009657   0.00772867 0.00990088 0.01169767\n",
      " 0.0095285  0.01207083 0.01042467 0.01729858 0.01655812 0.0181265\n",
      " 0.02433971 0.03335258 0.06219608 0.05779633 0.07177033 0.07233933\n",
      " 0.0816065  0.08615633 0.09697612 0.10885033 0.12538183 0.12301712\n",
      " 0.13495383 0.14317142 0.15558367 0.16993296 0.17463038 0.18871046\n",
      " 0.19663829 0.2104685  0.22723608 0.23152142 0.24507046 0.27065662\n",
      " 0.27706517 0.29152117 0.29058233 0.31229788 0.33957887 0.34666979\n",
      " 0.34691775 0.35783525 0.37728775 0.36926396 0.41662333 0.45217721\n",
      " 0.43530771 0.46389121 0.47069529 0.49482088 0.5152485  0.53174717\n",
      " 0.54626429 0.568932   0.59019046 0.61018358 0.62410204 0.63704667\n",
      " 0.67884154 0.68367362 0.70054004 0.71350096 0.73999462 0.75980075\n",
      " 0.77497363 0.82540704 0.834854   0.8539385  0.86787754 0.89078796\n",
      " 0.94145658 1.00257004 0.98274958 1.03531625 1.03951621 1.08504663\n",
      " 1.11032808 1.14073421]\n",
      "[ 92.  95.  97.  98.  99. 100. 101. 101. 102. 102. 103. 103. 103. 104.\n",
      " 104. 104. 105. 105. 105. 105. 106. 106. 106. 106. 106. 107. 107. 107.\n",
      " 107. 107. 107. 107. 108. 108. 108. 108. 108. 108. 108. 108. 109. 109.\n",
      " 109. 109. 109. 109. 109. 109. 109. 109. 110. 110. 110. 110. 110. 110.\n",
      " 110. 110. 110. 110. 110. 110. 111. 111. 111. 111. 111. 111. 111. 111.\n",
      " 111. 111. 111. 111. 111. 111. 111. 111. 112. 112.]\n"
     ]
    }
   ],
   "source": [
    "test_num = 80\n",
    "\n",
    "time_RG = np.ones(test_num)\n",
    "iter_RG = np.ones(test_num)\n",
    "for i in range(test_num):\n",
    "    iter_RG[i], c, time_RG[i] = RG(100*(i+1),0.001,0.4)\n",
    "print(time_RG)\n",
    "print(iter_RG)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.00401438 0.01617175 0.00810017 0.006456   0.00767029 0.00960538\n",
      " 0.01254554 0.01546642 0.01899117 0.02465767 0.03265779 0.04483092\n",
      " 0.05911963 0.04843892 0.05639242 0.06453592 0.09030229 0.09593008\n",
      " 0.10814121 0.1161085  0.12844183 0.14861167 0.15825225 0.15377571\n",
      " 0.18633087 0.18959962 0.20966083 0.23492304 0.2424795  0.24660033\n",
      " 0.27044158 0.31263733 0.30165446 0.31221033 0.35927208 0.32821479\n",
      " 0.33464054 0.37993842 0.39098129 0.40727596 0.43358113 0.46111829\n",
      " 0.46529658 0.48286442 0.5066395  0.53482483 0.54092879 0.56124292\n",
      " 0.59505746 0.62541642 0.65722579 0.66554975 0.69069329 0.71407558\n",
      " 0.73399283 0.76747183 0.79209388 0.81830042 0.89961667 0.96420442\n",
      " 0.89941746 0.95875242 1.008449   1.03475558 1.07519929 1.08084321\n",
      " 1.11051242 1.14896729 1.22567363 1.22529704 1.25530521 1.28854942\n",
      " 1.33852729 1.46983438 1.43545817 1.43679771 1.44677321 1.51875804\n",
      " 1.56002371 1.61565404]\n",
      "[66. 68. 69. 70. 71. 72. 72. 73. 73. 74. 74. 74. 74. 75. 75. 75. 75. 76.\n",
      " 76. 76. 76. 76. 76. 77. 77. 77. 77. 77. 77. 77. 78. 78. 78. 78. 78. 78.\n",
      " 78. 78. 78. 78. 78. 79. 79. 79. 79. 79. 79. 79. 79. 79. 79. 79. 79. 79.\n",
      " 79. 80. 80. 80. 80. 80. 80. 80. 80. 80. 80. 80. 80. 80. 80. 80. 80. 80.\n",
      " 80. 81. 81. 81. 81. 81. 81. 81.]\n"
     ]
    }
   ],
   "source": [
    "dim = 2000\n",
    "test_num = 80\n",
    "\n",
    "time_EGF = np.ones(test_num)\n",
    "iter_EGF = np.ones(test_num)\n",
    "for i in range(test_num):\n",
    "    iter_EGF[i], c, time_EGF[i] = EG(100*(i+1),0.001,0.7)\n",
    "print(time_EGF)\n",
    "print(iter_EGF)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "fig = plt.figure()\n",
    "ax = fig.add_subplot()\n",
    "ax.set_xlabel('#dimension')\n",
    "ax.set_ylabel('time')\n",
    "horizon = [100*(i+1) for i in range(test_num)]\n",
    "ax.plot(horizon,time_EG,'r',label='EG')\n",
    "ax.plot(horizon,time_RG,'b',label='RG')\n",
    "ax.plot(horizon,time_EGF,'y',label='EG-O')\n",
    "ax.legend()\n",
    "plt.savefig('numerical_1.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "HLVg7-y_gYkG",
    "outputId": "86b535c3-f85e-48aa-f5fb-de0fdde51df3"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(3514, 0.009999279974871616, 0.7273577910000313)\n",
      "(7906, 0.009999613302492067, 1.0023540000001958)\n"
     ]
    }
   ],
   "source": [
    "max_iters = 20000\n",
    "eps = 0.01\n",
    "dim = 1000\n",
    "eta_1 = 0.4\n",
    "eta_2 = 0.9\n",
    "\n",
    "print(FEG_AS(dim,eps, eta_2, max_iters))\n",
    "print(ARG(dim,eps,eta_1, max_iters))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "9TMUHQcP1uz2",
    "outputId": "29d80990-d491-4d16-d85a-1f82cabbefbe"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.05324512 0.09292425 0.18492821 0.25625921 0.24182937 0.32733058\n",
      " 0.41657392 0.47996237 0.57847829 0.96659554 1.04930862 1.30499612\n",
      " 1.57029025 2.05469921 2.66509475 3.56876567 4.46905175 5.32490492\n",
      " 5.45853621 6.29485167]\n",
      "[2001. 2829. 3465. 4001. 4473. 4899. 5292. 5657. 6001. 6325. 6634. 6929.\n",
      " 7212. 7484. 7746. 8001. 8247. 8486. 8718. 8945.]\n"
     ]
    }
   ],
   "source": [
    "max_iters = 20000\n",
    "test_num = 20\n",
    "\n",
    "time_ARG = np.ones(test_num)\n",
    "iter_ARG = np.ones(test_num)\n",
    "for i in range(test_num):\n",
    "    iter_ARG[i], c, time_ARG[i] = ARG(100*(i+1),0.01,0.5,max_iters)\n",
    "print(time_ARG)\n",
    "print(iter_ARG)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "E2kSAsWJxmQ4",
    "outputId": "5df763c2-8cdc-486e-c57b-8c54dbf6cdb1",
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0.06716187  0.13300425  0.2057985   0.274441    0.50561513  0.51335092\n",
      "  0.656298    0.71586642  0.87566983  1.33359575  1.70717804  2.16607425\n",
      "  2.94150404  3.76617917  4.66446458  5.6201535   7.50271183  9.41585112\n",
      "  9.99466367 11.32733825]\n",
      "[2001. 2830. 3465. 4001. 4473. 4900. 5293. 5658. 6001. 6326. 6634. 6929.\n",
      " 7212. 7484. 7747. 8001. 8247. 8486. 8719. 8945.]\n"
     ]
    }
   ],
   "source": [
    "max_iters = 20000\n",
    "test_num = 20\n",
    "\n",
    "time_FEG = np.ones(test_num)\n",
    "iter_FEG = np.ones(test_num)\n",
    "for i in range(test_num):\n",
    "    iter_FEG[i], c, time_FEG[i] = FEG_AS(100*(i+1),0.01,0.5,max_iters)\n",
    "print(time_FEG)\n",
    "print(iter_FEG)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.03604483 0.05572654 0.15191146 0.21209792 0.14928421 0.42515383\n",
      " 0.41273021 0.53183038 0.514847   0.90883988 1.20740883 1.29804971\n",
      " 1.61093258 1.85500058 2.34994604 3.23424054 3.74500558 4.57080087\n",
      " 5.07939683 5.98179121]\n",
      "[ 997. 1413. 1733. 1997. 2237. 2449. 2645. 2829. 2997. 3161. 3317. 3465.\n",
      " 3605. 3741. 3873. 3997. 4121. 4241. 4357. 4473.]\n"
     ]
    }
   ],
   "source": [
    "max_iters = 20000\n",
    "test_num = 20\n",
    "\n",
    "time_FEGF = np.ones(test_num)\n",
    "iter_FEGF = np.ones(test_num)\n",
    "for i in range(test_num):\n",
    "    iter_FEGF[i], c, time_FEGF[i] = FEG_AS(100*(i+1),0.01,1,max_iters)\n",
    "print(time_FEGF)\n",
    "print(iter_FEGF)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "fig = plt.figure()\n",
    "ax = fig.add_subplot()\n",
    "ax.set_xlabel('#dimension')\n",
    "ax.set_ylabel('time')\n",
    "horizon = [100*(i+1) for i in range(test_num)]\n",
    "ax.plot(horizon,time_FEG,'r',label='FEG')\n",
    "ax.plot(horizon,time_ARG,'b',label='ARG')\n",
    "ax.plot(horizon,time_FEGF,'y',label='FEG-O')\n",
    "ax.legend()\n",
    "plt.savefig('numerical_2.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "0.8[0.04921579 0.20446833 0.16564025 0.24968675 0.259979   0.45719867\n",
    " 0.46375646 0.77145192 0.72997325 1.210662   1.40825    1.62477729\n",
    " 1.90723629 2.38191283 3.06740313 4.30723654 4.92837817 5.8355865\n",
    " 8.16815571 8.31525688]\n",
    "\n",
    "0.9[0.03646842 0.13718579 0.21441958 0.148052   0.21931312 0.23572046\n",
    " 0.41980542 0.45947958 0.52140358 0.70296154 1.04469908 1.45463638\n",
    " 1.7191365  2.14751925 2.67847546 3.661731   4.15150267 4.57542687\n",
    " 5.10602887 6.29007013]\n",
    "\n",
    "1 [0.03604483 0.05572654 0.15191146 0.21209792 0.14928421 0.42515383\n",
    " 0.41273021 0.53183038 0.514847   0.90883988 1.20740883 1.29804971\n",
    " 1.61093258 1.85500058 2.34994604 3.23424054 3.74500558 4.57080087\n",
    " 5.07939683 5.98179121]\n"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [],
   "provenance": []
  },
  "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
