{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ad9db255",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import math"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b99b2ba8",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 100\n",
    "\n",
    "epsilon = list(np.random.uniform(-40, 40, n - 1))\n",
    "epsilon.append(n * np.sqrt(63) - np.sum(epsilon))\n",
    "\n",
    "xi = list(np.random.uniform(-4, 4, n - 1))\n",
    "xi.append(-n - np.sum(xi))\n",
    "\n",
    "p_uniform = np.ones(n)/n\n",
    "\n",
    "L_total = np.sqrt(np.mean(epsilon)**2 + np.mean(xi)**2)\n",
    "rho = 1/(4 * L_total)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "de86a6b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def operator_F(x, data, sample):\n",
    "    M = []\n",
    "    for i in sample:\n",
    "        M.append(np.array([[data[1][i], data[0][i]],[-data[0][i], data[1][i]]]))\n",
    "    return np.mean(M, axis = 0) @ x\n",
    "\n",
    "def operator_norm(x):\n",
    "    M = np.array([[np.mean(xi), np.mean(epsilon)], [-np.mean(epsilon), np.mean(xi)]])\n",
    "    return np.sum((M @ x)**2)\n",
    "\n",
    "def SPEG_operator(x_0, x_optimal, step1, step2, batchsize, n, data, operator, prob, iterations = 1000, trials = 10):\n",
    "    \n",
    "    relative_sq_operator_norm = []\n",
    "    initial_error = operator_norm(x_0)\n",
    "    \n",
    "    for trial in range(trials):\n",
    "        sq_operator_norm = []\n",
    "        \n",
    "        sample = np.random.choice(n, batchsize, p = prob)\n",
    "        op = operator(x_0, data, sample)\n",
    "        x = x_0 - step2 * op\n",
    "        \n",
    "        for iteration in range(iterations):\n",
    "            x_mid = x - step1 * op\n",
    "            sample = np.random.choice(n, batchsize, p = prob)\n",
    "            op = operator(x_mid, data, sample)\n",
    "            x = x - step2 * op\n",
    "     \n",
    "            sq_operator_norm.append(operator_norm(x_mid)/initial_error)\n",
    "        relative_sq_operator_norm.append(sq_operator_norm)\n",
    "        \n",
    "    return np.mean(relative_sq_operator_norm, axis = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "253466b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "no_iterations = 50000\n",
    "x_start = np.random.normal(0, 1, 2)\n",
    "\n",
    "batchsize_fraction = .1\n",
    "\n",
    "SPEG_operator_error = SPEG_operator(x_start, np.zeros(2), .0626, .00009, math.ceil(n * batchsize_fraction), n, (epsilon, xi), operator_F, p_uniform, iterations= no_iterations)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "3c5ce53f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'SPEG on WMVI')"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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": [
    "fig = plt.figure()\n",
    "markers_on = np.arange(0, no_iterations, no_iterations/10).astype(int)\n",
    "plt.plot(np.arange(no_iterations), SPEG_operator_error, '-bd', mfc = 'red', markevery = markers_on, markersize = 10, label = 'SPEG')\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.grid(True)\n",
    "plt.ylabel(\"Relative Operator Norm\", fontsize = 15)\n",
    "plt.xlabel(\"Number of Iterations\", fontsize = 15)\n",
    "plt.legend(fontsize = 10)\n",
    "plt.title(\"SPEG on WMVI\")\n",
    "\n",
    "plt.savefig(f'SPEG_on_WMVI_w_rel_op_err_batchsize = {batchsize_fraction}.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "09aa77a6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.125, 0.0625)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "1/L_total, max(2*rho, 1/(2*L_total))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "8adc1ae8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0005000000000000004"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gamma = .063\n",
    "min(gamma - 2*rho, 1/(4*L_total) - gamma/4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "5656102b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.000248"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "omega = .0005\n",
    "(1 - L_total * gamma) * omega"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "372869d8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([    0,  5000, 10000, 15000, 20000, 25000, 30000, 35000, 40000,\n",
       "       45000])"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "markers_on"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "7e5e5774",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.25440090e+00, 3.84219581e-01, 8.63362400e-02, 1.95309266e-02,\n",
       "       3.99200908e-01, 2.22251572e-02, 4.11012603e-02, 6.08261828e-04,\n",
       "       1.47906458e-04, 9.94653388e-06])"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "SPEG_operator_error[markers_on]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "d29254fa",
   "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": [
    "fig = plt.figure()\n",
    "markers_on = np.arange(0, no_iterations, no_iterations/20).astype(int)\n",
    "\n",
    "plt.plot(np.append(markers_on, no_iterations-1), SPEG_operator_error[np.append(markers_on, no_iterations-1)], '-bd', mfc = 'red', label = 'SPEG')\n",
    "plt.yscale('log')\n",
    "plt.grid(True)\n",
    "plt.ylabel(\"Relative Operator Norm\", fontsize = 15)\n",
    "plt.xlabel(\"Number of Iterations\", fontsize = 15)\n",
    "plt.legend(fontsize = 10)\n",
    "plt.savefig(f'SPEG_on_WMVI_w_rel_op_err_batchsize = {batchsize_fraction}.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "daec114f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([    0,  5000, 10000, 15000, 20000, 25000, 30000, 35000, 40000,\n",
       "       45000, 49999])"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.append(markers_on, no_iterations-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aa3e8329",
   "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.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
