{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib\n",
    "import random\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.stats import ortho_group\n",
    "import pickle\n",
    "import tqdm\n",
    "matplotlib.rcParams['figure.figsize'] = (8, 6)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Fixed dataset experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "N = 100\n",
    "d = 25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_data(path='quad_data.npy'):\n",
    "    pickle_off = open (path, 'rb')\n",
    "    dic = pickle.load(pickle_off)\n",
    "    return dic['A'], dic['B'], dic['C'], dic['SX'], dic['SY']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "A_list, B_list, C_list, SX_list, SY_list = load_data()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "x_0 = np.random.normal(10, 1.0, size=(d,1)) \n",
    "y_0 = np.random.normal(10, 1.0, size=(d,1))\n",
    "x_opt = np.zeros((d,1))\n",
    "y_opt = np.zeros((d,1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "K = 100\n",
    "runs = 50\n",
    "K_arr = np.arange(K+1)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Benchmarking for GDA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def GDA(A, B, C, SX, SY, x_0, y_0, x_opt, y_opt, K=10, lr=1e-6, mode='RR'):\n",
    "    X = [x_0]\n",
    "    Y = [y_0]\n",
    "    dx = x_0 - x_opt\n",
    "    dy = y_0 - y_opt\n",
    "    D = [np.matmul(dx.T, dx) + np.matmul(dy.T, dy)]\n",
    "    x_k = x_0\n",
    "    y_k = y_0\n",
    "    n = len(A)\n",
    "    \n",
    "    if mode == 'SO':\n",
    "        pi = np.random.permutation(n)\n",
    "    for k in range(K):\n",
    "        if mode == 'RR':\n",
    "            pi = np.random.permutation(n)\n",
    "        for j in range(n):\n",
    "            if mode == 'RR' or mode == 'SO':\n",
    "                i = pi[j]\n",
    "            elif mode == 'IG':\n",
    "                i = j\n",
    "            elif mode == 'US':\n",
    "                i = np.random.randint(n)\n",
    "            \n",
    "            grad_x = np.matmul(A[i], x_k) + np.matmul(B[i], y_k) + SX[i]\n",
    "            grad_y = np.matmul(B[i].T, x_k) - np.matmul(C[i], y_k) + SY[i]\n",
    "            x_k = x_k - lr * grad_x\n",
    "            y_k = y_k + lr * grad_y\n",
    "            \n",
    "        X.append(x_k)\n",
    "        Y.append(y_k)\n",
    "        dx = x_k - x_opt\n",
    "        dy = y_k - y_opt\n",
    "        D.append(np.matmul(dx.T, dx) + np.matmul(dy.T, dy))\n",
    "    X = np.array(X)\n",
    "    Y = np.array(Y)\n",
    "    D = np.array(D)\n",
    "    X = X.reshape((X.shape[0], X.shape[1]))\n",
    "    Y = Y.reshape((Y.shape[0], Y.shape[1]))\n",
    "    D = D.reshape((D.shape[0],))\n",
    "    return X, Y, D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "lr_US = 1.0 / (4 * d * N)\n",
    "lr_RR = 1.0 / (4 * d * N)\n",
    "lr_SO = 1.0 / (4 * d * N)\n",
    "lr_IG = 1.0 / (4 * d * N)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:15<00:00,  3.36it/s]\n"
     ]
    }
   ],
   "source": [
    "L_GDA_US = []\n",
    "L_GDA_RR = []\n",
    "L_GDA_SO = []\n",
    "L_GDA_IG = []\n",
    "\n",
    "for r in tqdm.tqdm(range(runs)):\n",
    "    _, _, D_US = GDA(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_US, mode='US')\n",
    "    _, _, D_RR = GDA(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_RR, mode='RR')\n",
    "    _, _, D_SO = GDA(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_SO, mode='SO')\n",
    "    _, _, D_IG = GDA(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_IG, mode='IG')\n",
    "    L_GDA_US.append(D_US / D_US[0])\n",
    "    L_GDA_RR.append(D_RR / D_RR[0])\n",
    "    L_GDA_SO.append(D_SO / D_SO[0])\n",
    "    L_GDA_IG.append(D_IG / D_IG[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "L_GDA_US = np.array(L_GDA_US)\n",
    "L_GDA_RR = np.array(L_GDA_RR)\n",
    "L_GDA_SO = np.array(L_GDA_SO)\n",
    "L_GDA_IG = np.array(L_GDA_IG)\n",
    "\n",
    "M_GDA_US = np.mean(L_GDA_US, axis=0)\n",
    "S_GDA_US = np.std(L_GDA_US, axis=0)\n",
    "E_GDA_US = 0.95 * S_GDA_US / np.sqrt(runs)\n",
    "\n",
    "M_GDA_RR = np.mean(L_GDA_RR, axis=0)\n",
    "S_GDA_RR = np.std(L_GDA_RR, axis=0)\n",
    "E_GDA_RR = 0.95 * S_GDA_RR / np.sqrt(runs)\n",
    "\n",
    "M_GDA_SO = np.mean(L_GDA_SO, axis=0)\n",
    "S_GDA_SO = np.std(L_GDA_SO, axis=0)\n",
    "E_GDA_SO = 0.95 * S_GDA_SO / np.sqrt(runs)\n",
    "\n",
    "M_GDA_IG = np.mean(L_GDA_IG, axis=0)\n",
    "S_GDA_IG = np.std(L_GDA_IG, axis=0)\n",
    "E_GDA_IG = 0.95 * S_GDA_IG / np.sqrt(runs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f1880fc7ba8>"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(K_arr, M_GDA_US, label='SGDA')\n",
    "plt.fill_between(K_arr, M_GDA_US + E_GDA_US, M_GDA_US - E_GDA_US, alpha=0.2)\n",
    "plt.plot(K_arr, M_GDA_RR, label='GDA-RR')\n",
    "plt.fill_between(K_arr, M_GDA_RR + E_GDA_RR, M_GDA_RR - E_GDA_RR, alpha=0.2)\n",
    "plt.plot(K_arr, M_GDA_SO, label='GDA-SO')\n",
    "plt.fill_between(K_arr, M_GDA_SO + E_GDA_SO, M_GDA_SO - E_GDA_SO, alpha=0.2)\n",
    "plt.plot(K_arr, M_GDA_IG, label='GDA-IG')\n",
    "plt.fill_between(K_arr, M_GDA_IG + E_GDA_IG, M_GDA_IG - E_GDA_IG, alpha=0.2)\n",
    "plt.xlabel('Epochs')\n",
    "plt.ylabel('Distance to Minimax Point')\n",
    "plt.grid()\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Benchmarking for PPM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "def PPM(A, B, C, SX, SY, x_0, y_0, x_opt, y_opt, K=10, lr=1e-6, mode='RR'):\n",
    "    X = [x_0]\n",
    "    Y = [y_0]\n",
    "    tsx = x_0.shape\n",
    "    tsy = y_0.shape\n",
    "    dx = x_0 - x_opt\n",
    "    dy = y_0 - y_opt\n",
    "    D = [np.matmul(dx.T, dx) + np.matmul(dy.T, dy)]\n",
    "    x_k = x_0\n",
    "    y_k = y_0\n",
    "    n = len(A)\n",
    "    \n",
    "    if mode == 'SO':\n",
    "        pi = np.random.permutation(n)\n",
    "    for k in range(K):\n",
    "        if mode == 'RR':\n",
    "            pi = np.random.permutation(n)\n",
    "        for j in range(n):\n",
    "            if mode == 'RR' or mode == 'SO':\n",
    "                i = pi[j]\n",
    "            elif mode == 'IG':\n",
    "                i = j\n",
    "            elif mode == 'US':\n",
    "                i = np.random.randint(n)\n",
    "            \n",
    "            w_k = np.concatenate((x_k - lr * SX[i], y_k + lr * SY[i]))\n",
    "            assert w_k.shape[0] == d * 2\n",
    "            I_d = np.eye(d)\n",
    "            P_k = np.block([[I_d + lr * A[i], lr * B[i]], [-lr * B[i].T, I_d + lr * C[i]]])\n",
    "            w_k = np.linalg.solve(P_k, w_k)\n",
    "            x_k = w_k[:d]\n",
    "            y_k = w_k[d:]\n",
    "            \n",
    "        X.append(x_k)\n",
    "        Y.append(y_k)\n",
    "        dx = x_k - x_opt\n",
    "        dy = y_k - y_opt\n",
    "        D.append(np.matmul(dx.T, dx) + np.matmul(dy.T, dy))\n",
    "    X = np.array(X)\n",
    "    Y = np.array(Y)\n",
    "    D = np.array(D)\n",
    "    X = X.reshape((X.shape[0], X.shape[1]))\n",
    "    Y = Y.reshape((Y.shape[0], Y.shape[1]))\n",
    "    D = D.reshape((D.shape[0],))\n",
    "    return X, Y, D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "lr_US = 1 / (d * N)\n",
    "lr_RR = 1 / (d * N)\n",
    "lr_SO = 1 / (d * N)\n",
    "lr_IG = 1 / (d * N)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [07:43<00:00,  9.59s/it]\n"
     ]
    }
   ],
   "source": [
    "L_PPM_US = []\n",
    "L_PPM_RR = []\n",
    "L_PPM_SO = []\n",
    "L_PPM_IG = []\n",
    "\n",
    "for r in tqdm.tqdm(range(runs)):\n",
    "    _, _, D_US = PPM(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_US, mode='US')\n",
    "    _, _, D_RR = PPM(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_RR, mode='RR')\n",
    "    _, _, D_SO = PPM(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_SO, mode='SO')\n",
    "    _, _, D_IG = PPM(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_IG, mode='IG')\n",
    "    L_PPM_US.append(D_US / D_US[0])\n",
    "    L_PPM_RR.append(D_RR / D_RR[0])\n",
    "    L_PPM_SO.append(D_SO / D_SO[0])\n",
    "    L_PPM_IG.append(D_IG / D_IG[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "L_PPM_US = np.array(L_PPM_US)\n",
    "L_PPM_RR = np.array(L_PPM_RR)\n",
    "L_PPM_SO = np.array(L_PPM_SO)\n",
    "L_PPM_IG = np.array(L_PPM_IG)\n",
    "\n",
    "M_PPM_US = np.mean(L_PPM_US, axis=0)\n",
    "S_PPM_US = np.std(L_PPM_US, axis=0)\n",
    "E_PPM_US = 0.95 * S_PPM_US / np.sqrt(runs)\n",
    "\n",
    "M_PPM_RR = np.mean(L_PPM_RR, axis=0)\n",
    "S_PPM_RR = np.std(L_PPM_RR, axis=0)\n",
    "E_PPM_RR = 0.95 * S_PPM_RR / np.sqrt(runs)\n",
    "\n",
    "M_PPM_SO = np.mean(L_PPM_SO, axis=0)\n",
    "S_PPM_SO = np.std(L_PPM_SO, axis=0)\n",
    "E_PPM_SO = 0.95 * S_PPM_SO / np.sqrt(runs)\n",
    "\n",
    "M_PPM_IG = np.mean(L_PPM_IG, axis=0)\n",
    "S_PPM_IG = np.std(L_PPM_IG, axis=0)\n",
    "E_PPM_IG = 0.95 * S_PPM_IG / np.sqrt(runs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f1880d6dd68>"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(K_arr, M_PPM_US, label='SPPM')\n",
    "plt.fill_between(K_arr, M_PPM_US + E_PPM_US, M_PPM_US - E_PPM_US, alpha=0.2)\n",
    "plt.plot(K_arr, M_PPM_RR, label='PPM-RR')\n",
    "plt.fill_between(K_arr, M_PPM_RR + E_PPM_RR, M_PPM_RR - E_PPM_RR, alpha=0.2)\n",
    "plt.plot(K_arr, M_PPM_SO, label='PPM-SO')\n",
    "plt.fill_between(K_arr, M_PPM_SO + E_PPM_SO, M_PPM_SO - E_PPM_SO, alpha=0.2)\n",
    "plt.plot(K_arr, M_PPM_IG, label='PPM-IG')\n",
    "plt.fill_between(K_arr, M_PPM_IG + E_PPM_IG, M_PPM_IG - E_PPM_IG, alpha=0.2)\n",
    "plt.xlabel('Epochs')\n",
    "plt.ylabel('Distance to Minimax Point')\n",
    "plt.yscale('log')\n",
    "plt.grid()\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Benchmarking for AGDA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "def AGDA(A, B, C, SX, SY, x_0, y_0, x_opt, y_opt, K=10, lr=1e-6, eta=1.0, mode='RR'):\n",
    "    X = [x_0]\n",
    "    Y = [y_0]\n",
    "    dx = x_0 - x_opt\n",
    "    dy = y_0 - y_opt\n",
    "    D = [np.matmul(dx.T, dx) + np.matmul(dy.T, dy)]\n",
    "    x_k = x_0\n",
    "    y_k = y_0\n",
    "    n = len(A)\n",
    "    \n",
    "    if mode == 'SO':\n",
    "        pi = np.random.permutation(n)\n",
    "    for k in range(K):\n",
    "        if mode == 'RR':\n",
    "            pi = np.random.permutation(n)\n",
    "        for j in range(n):\n",
    "            if mode == 'RR' or mode == 'SO':\n",
    "                i = pi[j]\n",
    "            elif mode == 'IG':\n",
    "                i = j\n",
    "            elif mode == 'US':\n",
    "                i = np.random.randint(n)\n",
    "                \n",
    "            grad_x = np.matmul(A[i], x_k) + np.matmul(B[i], y_k) + SX[i]\n",
    "            x_k = x_k - lr * grad_x\n",
    "            \n",
    "        if mode == 'RR':\n",
    "            pi = np.random.permutation(n)\n",
    "        for j in range(n):\n",
    "            if mode == 'RR' or mode == 'SO':\n",
    "                i = pi[j]\n",
    "            elif mode == 'IG':\n",
    "                i = j\n",
    "            elif mode == 'US':\n",
    "                i = np.random.randint(n)\n",
    "            grad_y = np.matmul(B[i].T, x_k) - np.matmul(C[i], y_k) + SY[i]\n",
    "            y_k = y_k + lr * eta * grad_y  \n",
    "            \n",
    "        X.append(x_k)\n",
    "        Y.append(y_k)\n",
    "        dx = x_k - x_opt\n",
    "        dy = y_k - y_opt\n",
    "        D.append(np.matmul(dx.T, dx) + np.matmul(dy.T, dy))\n",
    "        \n",
    "    X = np.array(X)\n",
    "    Y = np.array(Y)\n",
    "    D = np.array(D)\n",
    "    X = X.reshape((X.shape[0], X.shape[1]))\n",
    "    Y = Y.reshape((Y.shape[0], Y.shape[1]))\n",
    "    D = D.reshape((D.shape[0],))\n",
    "    return X, Y, D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "def StocAGDA(A, B, C, SX, SY, x_0, y_0, x_opt, y_opt, K=10, lr=1e-6, eta=1.0):\n",
    "    X = [x_0]\n",
    "    Y = [y_0]\n",
    "    dx = x_0 - x_opt\n",
    "    dy = y_0 - y_opt\n",
    "    D = [np.matmul(dx.T, dx) + np.matmul(dy.T, dy)]\n",
    "    x_k = x_0\n",
    "    y_k = y_0\n",
    "    n = len(A)\n",
    "    \n",
    "    for k in range(K):\n",
    "        for j in range(n):\n",
    "            i = np.random.randint(n)\n",
    "            grad_x = np.matmul(A[i], x_k) + np.matmul(B[i], y_k) + SX[i]\n",
    "            x_k = x_k - lr * grad_x\n",
    "            i = np.random.randint(n)\n",
    "            grad_y = np.matmul(B[i].T, x_k) - np.matmul(C[i], y_k) + SY[i]\n",
    "            y_k = y_k + lr * eta * grad_y\n",
    "            \n",
    "        X.append(x_k)\n",
    "        Y.append(y_k)\n",
    "        dx = x_k - x_opt\n",
    "        dy = y_k - y_opt\n",
    "        D.append(np.matmul(dx.T, dx) + np.matmul(dy.T, dy))\n",
    "    X = np.array(X)\n",
    "    Y = np.array(Y)\n",
    "    D = np.array(D)\n",
    "    X = X.reshape((X.shape[0], X.shape[1]))\n",
    "    Y = Y.reshape((Y.shape[0], Y.shape[1]))\n",
    "    D = D.reshape((D.shape[0],))\n",
    "    return X, Y, D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "lr_US = 1 / (5 * d * N)\n",
    "lr_RR = 1 / ( d * N)\n",
    "lr_IG = 1 / ( d * N)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:14<00:00,  3.52it/s]\n"
     ]
    }
   ],
   "source": [
    "L_AGDA_US = []\n",
    "L_AGDA_RR = []\n",
    "#L_AGDA_SO = []\n",
    "L_AGDA_IG = []\n",
    "\n",
    "for r in tqdm.tqdm(range(runs)):\n",
    "    _, _, D_US = StocAGDA(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_US)\n",
    "    _, _, D_RR = AGDA(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_RR, mode='RR')\n",
    "    _, _, D_IG = AGDA(A_list, B_list, C_list, SX_list, SY_list, x_0.copy(), y_0.copy(), x_opt.copy(), y_opt.copy(), K, lr_IG, mode='IG')\n",
    "    L_AGDA_US.append(D_US / D_US[0])\n",
    "    L_AGDA_RR.append(D_RR / D_RR[0])\n",
    "    L_AGDA_IG.append(D_IG / D_IG[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "L_AGDA_US = np.array(L_AGDA_US)\n",
    "L_AGDA_RR = np.array(L_AGDA_RR)\n",
    "L_AGDA_IG = np.array(L_AGDA_IG)\n",
    "\n",
    "M_AGDA_US = np.mean(L_AGDA_US, axis=0)\n",
    "S_AGDA_US = np.std(L_AGDA_US, axis=0)\n",
    "E_AGDA_US = 0.95 * S_AGDA_US / np.sqrt(runs)\n",
    "\n",
    "M_AGDA_RR = np.mean(L_AGDA_RR, axis=0)\n",
    "S_AGDA_RR = np.std(L_AGDA_RR, axis=0)\n",
    "E_AGDA_RR = 0.95 * S_AGDA_RR / np.sqrt(runs)\n",
    "\n",
    "M_AGDA_IG = np.mean(L_AGDA_IG, axis=0)\n",
    "S_AGDA_IG = np.std(L_AGDA_IG, axis=0)\n",
    "E_AGDA_IG = 0.95 * S_AGDA_IG / np.sqrt(runs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f1880c56748>"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(K_arr, M_AGDA_US, label='Stochastic AGDA')\n",
    "plt.fill_between(K_arr, M_AGDA_US + E_AGDA_US, M_AGDA_US - E_AGDA_US, alpha=0.2)\n",
    "plt.plot(K_arr, M_AGDA_RR, label='AGDA-RR')\n",
    "plt.fill_between(K_arr, M_AGDA_RR + E_AGDA_RR, M_AGDA_RR - E_AGDA_RR, alpha=0.2)\n",
    "plt.plot(K_arr, M_AGDA_IG, label='AGDA-IG')\n",
    "plt.fill_between(K_arr, M_AGDA_IG + E_AGDA_IG, M_AGDA_IG - E_AGDA_IG, alpha=0.2)\n",
    "plt.xlabel('Epochs')\n",
    "plt.ylabel('Distance to Minimax Point')\n",
    "plt.yscale('log')\n",
    "plt.grid()\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
