{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 15,
   "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": [
    "## Averaging over multiple datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "N = 100\n",
    "nc = 80\n",
    "d = 25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "scale_del_norm = 10.0 / 5\n",
    "scale_mu_norm = 0.1 / 5\n",
    "scale_b_norm = 1.0 / 5\n",
    "\n",
    "scale_del = scale_del_norm * d\n",
    "scale_mu = scale_mu_norm * d\n",
    "scale_b = scale_b_norm * d"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "def gen_data():\n",
    "    delta_A = np.diag(np.random.uniform(scale_del, 2 * scale_del, (d,)))\n",
    "    delta_B = np.diag(np.random.uniform(scale_del, 2 * scale_del, (d,)))\n",
    "    delta_C = np.diag(np.random.uniform(scale_del, 2 * scale_del, (d,)))\n",
    "    delta_S = np.random.uniform(scale_del, 2 * scale_del, (d, 1))\n",
    "\n",
    "    mu_X = np.diag(np.random.uniform(scale_mu, 2 * scale_mu, (d,)))\n",
    "    mu_Y = np.diag(np.random.uniform(scale_mu, 2 * scale_mu, (d,)))\n",
    "    B = np.diag(np.random.uniform(scale_b, 2 * scale_b, (d,)))\n",
    "\n",
    "    PA = ortho_group.rvs(dim=d)\n",
    "    PB = ortho_group.rvs(dim=d)\n",
    "    PC = ortho_group.rvs(dim=d)\n",
    "\n",
    "    A_list = [-delta_A for _ in range(N - nc)]\n",
    "    B_list = []\n",
    "    C_list = [-delta_C for _ in range(N - nc)]\n",
    "    SX_list = [-delta_S for _ in range(N - nc)]\n",
    "    SY_list = [-delta_S for _ in range(N - nc)]\n",
    "\n",
    "    for _ in range(nc):\n",
    "        A_list.append((N * mu_X + (N-nc) * delta_A) / nc)\n",
    "        C_list.append((N * mu_Y + (N-nc) * delta_C) / nc)\n",
    "        SX_list.append(((N - nc) * delta_S) / nc)\n",
    "        SY_list.append(((N - nc) * delta_S) / nc)\n",
    "\n",
    "    for i in range(N):\n",
    "        if i % 2 == 0:\n",
    "            B_list.append(delta_B + 2 * B)\n",
    "        else:\n",
    "            B_list.append(-delta_B)\n",
    "        \n",
    "    random.shuffle(A_list)\n",
    "    random.shuffle(B_list)\n",
    "    random.shuffle(C_list)\n",
    "    random.shuffle(SX_list)\n",
    "    random.shuffle(SY_list)\n",
    "\n",
    "    for i in range(N):\n",
    "        A_list[i] = np.matmul(PA, np.matmul(A_list[i], PA.T))\n",
    "        B_list[i] = np.matmul(PB, np.matmul(B_list[i], PB.T))\n",
    "        C_list[i] = np.matmul(PC, np.matmul(C_list[i], PC.T))\n",
    "    return A_list, B_list, C_list, SX_list, SY_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "def AGDA(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",
    "            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 * 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": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "def StocAGDA(A, B, C, SX, SY, x_0, y_0, x_opt, y_opt, K=10, lr=1e-6):\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 * 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": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "x_opt = np.zeros((d,1))\n",
    "y_opt = np.zeros((d,1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "K = 100\n",
    "runs = 20\n",
    "inter_runs = 5\n",
    "K_arr = np.arange(K+1)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Benchmarking for GDA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "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": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "lr_US = 1.3 / (4 * d * N)\n",
    "lr_RR = 1.3 / (4 * d * N)\n",
    "lr_SO = 1.3 / (4 * d * N)\n",
    "lr_IG = 1.3 / (4 * d * N)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 20/20 [00:31<00:00,  1.62s/it]\n"
     ]
    }
   ],
   "source": [
    "L_GDA_US = []\n",
    "L_GDA_RR = []\n",
    "L_GDA_SO = []\n",
    "L_GDA_IG = []\n",
    "\n",
    "for _ in tqdm.tqdm(range(runs)):\n",
    "    A_list, B_list, C_list, SX_list, SY_list = gen_data()\n",
    "    x_0 = np.random.normal(10, 1.0, size=(d,1)) \n",
    "    y_0 = np.random.normal(10, 1.0, size=(d,1))\n",
    "    dx = x_0 - x_opt\n",
    "    dy = y_0 - y_opt\n",
    "    sqd = np.matmul(dx.T, dx) + np.matmul(dy.T, dy)\n",
    "    sqd = sqd[0]\n",
    "    m_US = np.zeros((K+1,))\n",
    "    m_RR = np.zeros((K+1,))\n",
    "    m_SO = np.zeros((K+1,))\n",
    "    m_IG = np.zeros((K+1,))\n",
    "    for _ in range(inter_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",
    "        m_US = m_US + D_US / (sqd * inter_runs)\n",
    "        m_RR = m_RR + D_RR / (sqd * inter_runs)\n",
    "        m_SO = m_SO + D_SO / (sqd * inter_runs)\n",
    "        m_IG = m_IG + D_IG / (sqd * inter_runs)\n",
    "    L_GDA_US.append(m_US)\n",
    "    L_GDA_RR.append(m_RR)\n",
    "    L_GDA_SO.append(m_SO)\n",
    "    L_GDA_IG.append(m_IG)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "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": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f5273fe5978>"
      ]
     },
     "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_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": 28,
   "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": 29,
   "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": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 20/20 [15:13<00:00, 44.31s/it]\n"
     ]
    }
   ],
   "source": [
    "L_PPM_US = []\n",
    "L_PPM_RR = []\n",
    "L_PPM_SO = []\n",
    "L_PPM_IG = []\n",
    "\n",
    "for _ in tqdm.tqdm(range(runs)):\n",
    "    A_list, B_list, C_list, SX_list, SY_list = gen_data()\n",
    "    x_0 = np.random.normal(10, 1.0, size=(d,1)) \n",
    "    y_0 = np.random.normal(10, 1.0, size=(d,1))\n",
    "    dx = x_0 - x_opt\n",
    "    dy = y_0 - y_opt\n",
    "    sqd = np.matmul(dx.T, dx) + np.matmul(dy.T, dy)\n",
    "    \n",
    "    m_US = np.zeros((K+1,))\n",
    "    m_RR = np.zeros((K+1,))\n",
    "    m_SO = np.zeros((K+1,))\n",
    "    m_IG = np.zeros((K+1,))\n",
    "    \n",
    "    for _ in range(inter_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",
    "        m_US = m_US + D_US / (sqd * inter_runs)\n",
    "        m_RR = m_RR + D_RR / (sqd * inter_runs)\n",
    "        m_SO = m_SO + D_SO / (sqd * inter_runs)\n",
    "        m_IG = m_IG + D_IG / (sqd * inter_runs)\n",
    "    L_PPM_US.append(m_US)\n",
    "    L_PPM_RR.append(m_RR)\n",
    "    L_PPM_SO.append(m_SO)\n",
    "    L_PPM_IG.append(m_IG)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "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).reshape((K+1,))\n",
    "S_PPM_US = np.std(L_PPM_US, axis=0).reshape((K+1,))\n",
    "E_PPM_US = 0.95 * S_PPM_US / np.sqrt(runs)\n",
    "\n",
    "M_PPM_RR = np.mean(L_PPM_RR, axis=0).reshape((K+1,))\n",
    "S_PPM_RR = np.std(L_PPM_RR, axis=0).reshape((K+1,))\n",
    "E_PPM_RR = 0.95 * S_PPM_RR / np.sqrt(runs)\n",
    "\n",
    "M_PPM_SO = np.mean(L_PPM_SO, axis=0).reshape((K+1,))\n",
    "S_PPM_SO = np.std(L_PPM_SO, axis=0).reshape((K+1,))\n",
    "E_PPM_SO = 0.95 * S_PPM_SO / np.sqrt(runs)\n",
    "\n",
    "M_PPM_IG = np.mean(L_PPM_IG, axis=0).reshape((K+1,))\n",
    "S_PPM_IG = np.std(L_PPM_IG, axis=0).reshape((K+1,))\n",
    "E_PPM_IG = 0.95 * S_PPM_IG / np.sqrt(runs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f5273f5e8d0>"
      ]
     },
     "execution_count": 32,
     "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": 33,
   "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": 34,
   "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": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "lr_US = 1 / (5 * d * N)\n",
    "lr_RR = 1.4 / ( d * N)\n",
    "lr_IG = 1.4 / ( d * N)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 20/20 [00:26<00:00,  1.35s/it]\n"
     ]
    }
   ],
   "source": [
    "L_AGDA_US = []\n",
    "L_AGDA_RR = []\n",
    "L_AGDA_IG = []\n",
    "\n",
    "for _ in tqdm.tqdm(range(runs)):\n",
    "    A_list, B_list, C_list, SX_list, SY_list = gen_data()\n",
    "    x_0 = np.random.normal(10, 1.0, size=(d,1)) \n",
    "    y_0 = np.random.normal(10, 1.0, size=(d,1))\n",
    "    dx = x_0 - x_opt\n",
    "    dy = y_0 - y_opt\n",
    "    sqd = np.matmul(dx.T, dx) + np.matmul(dy.T, dy)\n",
    "    sqd = sqd[0]\n",
    "    m_US = np.zeros((K+1,))\n",
    "    m_RR = np.zeros((K+1,))\n",
    "    m_IG = np.zeros((K+1,))\n",
    "    for _ in range(inter_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",
    "        m_US = m_US + D_US / (sqd * inter_runs)\n",
    "        m_RR = m_RR + D_RR / (sqd * inter_runs)\n",
    "        m_IG = m_IG + D_IG / (sqd * inter_runs)\n",
    "    L_AGDA_US.append(m_US)\n",
    "    L_AGDA_RR.append(m_RR)\n",
    "    L_AGDA_IG.append(m_IG)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "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",
    "\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": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f5273d51898>"
      ]
     },
     "execution_count": 38,
     "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
}
