{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "90152fe9-6f7f-4f68-a35f-7dbd57d816f3",
      "metadata": {
        "id": "90152fe9-6f7f-4f68-a35f-7dbd57d816f3"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import time\n",
        "import pandas as pd\n",
        "import csv"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "8f09a8dd-347e-4ce9-9cec-54e1635fecb2",
      "metadata": {
        "id": "8f09a8dd-347e-4ce9-9cec-54e1635fecb2"
      },
      "outputs": [],
      "source": [
        "n = 500\n",
        "m = 100\n",
        "p = 50\n",
        "l = 5\n",
        "q = 60\n",
        "\n",
        "\n",
        "nv = 10**3\n",
        "delta = 10**(-4)\n",
        "r = 5\n",
        "B = 1\n",
        "\n",
        "np.random.seed(1)\n",
        "D = np.random.normal(loc=0, scale=1, size=(m, p))\n",
        "D = D/np.linalg.norm( D , axis = 0 ).reshape(1,-1)\n",
        "\n",
        "U = np.random.normal(loc=0, scale=1, size=(p, l))\n",
        "V = np.random.normal(loc=0, scale=1, size=(n, l))\n",
        "C = U @ V.T / ( np.linalg.norm(U, ord = 2) * np.linalg.norm(V, ord = 2))\n",
        "\n",
        "A_old = D@C\n",
        "\n",
        "C = np.vstack((C, np.zeros((q-p,n))))\n",
        "\n",
        "A_new = np.random.normal(loc=0, scale=1, size=(m, nv))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "3528f614-1c8d-4fc9-a172-70aaae21c207",
      "metadata": {
        "id": "3528f614-1c8d-4fc9-a172-70aaae21c207"
      },
      "outputs": [],
      "source": [
        "def LMO_LMO(x1 , x2 , y, x1_lmo, x2_lmo, y_lmo, Lyy, a, b, budget):\n",
        "\n",
        "    filename = 'lmo_lmo.csv'\n",
        "    iters = []\n",
        "    gap = []\n",
        "    time_elapsed = []\n",
        "    oracles = []\n",
        "\n",
        "    y0 = y\n",
        "    elapsed_time = 0\n",
        "    t = 0\n",
        "    while elapsed_time <= budget:\n",
        "\n",
        "        start = time.time()\n",
        "\n",
        "        tau = (2 / ( t + 10 ))**a\n",
        "        beta = 0.01 / ( t + 10 )**b\n",
        "\n",
        "        grad_x1, grad_x2, grad_y = gradL( x1, x2, y)\n",
        "\n",
        "        v1 = x1_lmo( grad_x1 )\n",
        "        x1_new = ( 1 - tau ) * x1 + tau * v1\n",
        "\n",
        "        v2 = x2_lmo( grad_x2 )\n",
        "        x2_new = ( 1 - tau ) * x2 + tau * v2\n",
        "\n",
        "        u = y_lmo( grad_y - beta * ( y - y0 ) )\n",
        "        gamma = min( 1 , (grad_y - beta * ( y - y0 ))* ( u - y ) / ( ( Lyy + beta ) * np.linalg.norm( u - y )**2) )\n",
        "        y_new = ( 1 - gamma ) * y + gamma * u\n",
        "\n",
        "        t += 1\n",
        "\n",
        "        end = time.time()\n",
        "\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        elapsed_time += end - start\n",
        "\n",
        "\n",
        "        primal_gap1 = abs(np.sum( grad_x1*( x1 -v1 ) ))\n",
        "        primal_gap2 = abs(np.sum( grad_x2 * ( x2 -v2 ) ))\n",
        "\n",
        "        primal_gap = primal_gap1 + primal_gap2\n",
        "\n",
        "        w = y_lmo( grad_y )\n",
        "        dual_gap = abs(grad_y * ( w - y ))\n",
        "\n",
        "        x1 = x1_new\n",
        "        x2 = x2_new\n",
        "\n",
        "        y = y_new\n",
        "\n",
        "\n",
        "        gap.append( primal_gap+ dual_gap)\n",
        "\n",
        "        # print('Iteration: {}, Primal: {}, Dual: {}, Total: {}'.format(t, primal_gap, dual_gap, primal_gap+ dual_gap))\n",
        "\n",
        "\n",
        "    df = pd.DataFrame({\n",
        "        't': iters,\n",
        "        'gap': gap,\n",
        "        'time_elapsed': time_elapsed})\n",
        "    df.to_csv(filename, index=False)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "ddf414f7-d951-4623-afc0-e3b56727eb05",
      "metadata": {
        "id": "ddf414f7-d951-4623-afc0-e3b56727eb05"
      },
      "outputs": [],
      "source": [
        "def LMO_PO(x1 , x2 , y, x1_lmo, x2_lmo, y_po, Lyy, a, b, budget):\n",
        "\n",
        "    filename = 'lmo_po.csv'\n",
        "    iters = []\n",
        "    gap = []\n",
        "    time_elapsed = []\n",
        "    oracles = []\n",
        "\n",
        "    y0 = y\n",
        "    elapsed_time = 0\n",
        "    t = 0\n",
        "    while elapsed_time <= budget:\n",
        "\n",
        "        start = time.time()\n",
        "\n",
        "        tau = (2 / ( t + 10 ))**a\n",
        "        beta = 0.01 / ( t + 10 )**b\n",
        "        gamma = 1 / ( Lyy + beta  )\n",
        "\n",
        "        grad_x1, grad_x2, grad_y = gradL( x1, x2, y)\n",
        "\n",
        "        v1 = x1_lmo( grad_x1 )\n",
        "        x1_new = ( 1 - tau ) * x1 + tau * v1\n",
        "\n",
        "        v2 = x2_lmo( grad_x2 )\n",
        "        x2_new = ( 1 - tau ) * x2 + tau * v2\n",
        "\n",
        "        y_new = y_po( y + gamma * ( grad_y - beta * ( y - y0 ) ) )\n",
        "\n",
        "        t += 1\n",
        "\n",
        "\n",
        "        end = time.time()\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        elapsed_time += end - start\n",
        "\n",
        "        primal_gap1 = abs(np.sum( grad_x1 *( x1 -v1 ) ))\n",
        "        primal_gap2 = abs(np.sum( grad_x2 * ( x2 -v2 ) ))\n",
        "\n",
        "        primal_gap = primal_gap1 + primal_gap2\n",
        "\n",
        "        dual_gap = np.linalg.norm( y_po( y + gamma *  grad_y   )   - y )/gamma\n",
        "\n",
        "        x1 = x1_new\n",
        "        x2 = x2_new\n",
        "\n",
        "        y = y_new\n",
        "\n",
        "\n",
        "        gap.append( primal_gap + dual_gap)\n",
        "\n",
        "        # print('Iteration: {}, Primal: {}, Dual: {}, Total: {}'.format(t, primal_gap, dual_gap, primal_gap+ dual_gap))\n",
        "\n",
        "\n",
        "    df = pd.DataFrame({\n",
        "        't': iters,\n",
        "        'gap': gap,\n",
        "        'time_elapsed': time_elapsed})\n",
        "    df.to_csv(filename, index=False)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "9c91c565-60ef-4887-8a3c-c2adf72b54c9",
      "metadata": {
        "id": "9c91c565-60ef-4887-8a3c-c2adf72b54c9"
      },
      "outputs": [],
      "source": [
        "def PO_LMO(x1 , x2 , y, x1_po, x2_po, y_lmo, Lyy, Lyx, Lxx, a, b, budget):\n",
        "\n",
        "    filename = 'po_lmo.csv'\n",
        "    iters = []\n",
        "    gap = []\n",
        "    time_elapsed = []\n",
        "    oracles = []\n",
        "\n",
        "    y0 = y\n",
        "    elapsed_time = 0\n",
        "    t = 0\n",
        "    while elapsed_time <= budget:\n",
        "\n",
        "        start = time.time()\n",
        "\n",
        "        # tau =  100  / ( 1*( t + 1 )**a +  5*Lxx/2 + (13*Lyx**2)*( t + 1 )**b / 2 )\n",
        "        tau = 100/ ( t + 10 )**a\n",
        "        beta = 0.01 / ( t + 10 )**b\n",
        "\n",
        "        grad_x1, grad_x2, grad_y = gradL( x1, x2, y)\n",
        "\n",
        "        x1_new = x1_po( x1 - tau * grad_x1 )\n",
        "        x2_new = x2_po( x2 - tau * grad_x2 )\n",
        "\n",
        "\n",
        "        u = y_lmo( grad_y - beta * ( y - y0 ) )\n",
        "        gamma = min( 1 , ( grad_y - beta * ( y - y0 ) )* ( u - y ) / ( ( Lyy + beta ) * np.linalg.norm( u - y )**2 ) )\n",
        "        y_new = ( 1 - gamma ) * y + gamma * u\n",
        "\n",
        "        t += 1\n",
        "\n",
        "        end = time.time()\n",
        "\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "\n",
        "        elapsed_time += end - start\n",
        "\n",
        "        primal_gap = np.linalg.norm( np.vstack([x1,x2.T]) - np.vstack([x1_new,x2_new.T]) ) / tau\n",
        "        x1 = x1_new\n",
        "        x2 = x2_new\n",
        "\n",
        "        w = y_lmo( grad_y )\n",
        "        dual_gap = abs(grad_y * ( w - y ))\n",
        "        y = y_new\n",
        "\n",
        "        gap.append( primal_gap + dual_gap)\n",
        "\n",
        "        # print('Iteration: {}, Primal: {}, Dual: {}, Total: {}'.format(t, primal_gap, dual_gap, primal_gap+ dual_gap))\n",
        "\n",
        "\n",
        "    df = pd.DataFrame({\n",
        "        't': iters,\n",
        "        'gap': gap,\n",
        "        'time_elapsed': time_elapsed})\n",
        "    df.to_csv(filename, index=False)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "6d0383e3-301a-4397-97dc-3d30b36a3420",
      "metadata": {
        "id": "6d0383e3-301a-4397-97dc-3d30b36a3420"
      },
      "outputs": [],
      "source": [
        "def R_PDCG(x1 , x2 , y, x1_lmo, x2_lmo, y_lmo, Lyy, tau, mu, alpha, T, budget):\n",
        "\n",
        "    filename = 'r_pdcg.csv'\n",
        "    iters = []\n",
        "    gap = []\n",
        "    time_elapsed = []\n",
        "    oracles = []\n",
        "\n",
        "    y0 = y\n",
        "\n",
        "    elapsed_time = 0\n",
        "    t = 0\n",
        "    while elapsed_time <= budget:\n",
        "\n",
        "        start = time.time()\n",
        "\n",
        "        grad_x1, grad_x2, grad_y = gradL( x1, x2, y)\n",
        "\n",
        "\n",
        "        v1 = x1_lmo( grad_x1 )\n",
        "        x1_new = ( 1 - tau ) * x1 + tau * v1\n",
        "\n",
        "        v2 = x2_lmo( grad_x2 )\n",
        "        x2_new = ( 1 - tau ) * x2 + tau * v2\n",
        "\n",
        "        u = y_lmo( grad_y - mu * ( y - y0 ) )\n",
        "        gamma = min (1 , alpha * np.linalg.norm( grad_y - mu * ( y - y0 )  ) / ( 4 * ( mu + Lyy ) ) )\n",
        "        y_new = ( 1 - gamma ) * y + gamma * u\n",
        "\n",
        "        t += 1\n",
        "\n",
        "        end = time.time()\n",
        "\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        elapsed_time += end-start\n",
        "\n",
        "        primal_gap1 = abs(np.sum( grad_x1 * ( x1 -v1 ) ))\n",
        "        primal_gap2 = abs(np.sum( grad_x2 * ( x2 -v2 ) ))\n",
        "        primal_gap = primal_gap1 + primal_gap2\n",
        "\n",
        "        w = y_lmo(grad_y)\n",
        "        dual_gap = abs(grad_y * (w - y))\n",
        "\n",
        "        x1 = x1_new\n",
        "        x2 = x2_new\n",
        "\n",
        "        y = y_new\n",
        "\n",
        "        gap.append( primal_gap + dual_gap )\n",
        "        # print('Iteration: {}, Primal: {}, Dual: {}, Total: {}'.format(t, primal_gap, dual_gap, primal_gap+ dual_gap))\n",
        "\n",
        "\n",
        "    df = pd.DataFrame({\n",
        "        't': iters,\n",
        "        'gap': gap,\n",
        "        'time_elapsed': time_elapsed})\n",
        "    df.to_csv(filename, index=False)\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "ba520b3d-8007-4d20-a201-dd34edacd9ff",
      "metadata": {
        "id": "ba520b3d-8007-4d20-a201-dd34edacd9ff"
      },
      "outputs": [],
      "source": [
        "def CG_RPGA(x1 , x2 , y, x1_lmo, x2_lmo, y_po, Lyy,  tau, mu, sigma, T, budget):\n",
        "\n",
        "    filename = 'cg_rpga.csv'\n",
        "    iters = []\n",
        "    gap = []\n",
        "    time_elapsed = []\n",
        "    oracles = []\n",
        "\n",
        "    y0 = y\n",
        "    elapsed_time = 0\n",
        "    t = 0\n",
        "    while elapsed_time <= budget:\n",
        "\n",
        "        start = time.time()\n",
        "\n",
        "\n",
        "        grad_x1, grad_x2, grad_y = gradL( x1, x2, y)\n",
        "\n",
        "        v1 = x1_lmo( grad_x1 )\n",
        "        x1_new = ( 1 - tau ) * x1 + tau * v1\n",
        "\n",
        "        v2 = x2_lmo( grad_x2 )\n",
        "        x2_new = ( 1 - tau ) * x2 + tau * v2\n",
        "\n",
        "        y_new = y_po( y + sigma * ( grad_y - mu * ( y - y0 ) ) )\n",
        "\n",
        "\n",
        "        t += 1\n",
        "\n",
        "\n",
        "        end = time.time()\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        elapsed_time += end - start\n",
        "\n",
        "        primal_gap1 = abs(np.sum( grad_x1 * ( x1 - v1 ) ))\n",
        "        primal_gap2 = abs(np.sum( grad_x2 * ( x2 - v2 ) ))\n",
        "        primal_gap = primal_gap1 + primal_gap2\n",
        "\n",
        "        dual_gap = np.linalg.norm( y_po( y + sigma *  grad_y ) - y )/sigma\n",
        "\n",
        "        x1 = x1_new\n",
        "        x2 = x2_new\n",
        "\n",
        "        y = y_new\n",
        "\n",
        "        gap.append( primal_gap + dual_gap)\n",
        "\n",
        "        # print('Iteration: {}, Primal: {}, Dual: {}, Total: {}'.format(t, primal_gap, dual_gap, primal_gap+ dual_gap))\n",
        "\n",
        "\n",
        "    df = pd.DataFrame({\n",
        "        't': iters,\n",
        "        'gap': gap,\n",
        "        'time_elapsed': time_elapsed})\n",
        "    df.to_csv(filename, index=False)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "02296656-0b7a-4997-8714-8ff9ed0b4c13",
      "metadata": {
        "id": "02296656-0b7a-4997-8714-8ff9ed0b4c13"
      },
      "outputs": [],
      "source": [
        "def AGP(x1, x2, y, x1_po, x2_po, y_po, tau, eta_bar, rho_bar, Lxx, Lyx, Lyy, T, budget):\n",
        "\n",
        "    filename = 'agp.csv'\n",
        "    iters = []\n",
        "    gap = []\n",
        "    time_elapsed = []\n",
        "    oracles = []\n",
        "\n",
        "    y0 = y\n",
        "    elapsed_time = 0\n",
        "    t = 0\n",
        "    while elapsed_time <= budget:\n",
        "\n",
        "        start = time.time()\n",
        "\n",
        "\n",
        "        grad_x1, grad_x2, grad_y = gradL( x1, x2, y)\n",
        "\n",
        "        b = 0\n",
        "        c = 19/(20*rho_bar*(t+1)**1/4)\n",
        "        beta_bar = rho_bar*Lyx**2 + 16*tau*Lyx**2/(rho_bar*c**2) -2*eta_bar\n",
        "        beta = eta_bar + beta_bar\n",
        "        gamma = 1/rho_bar\n",
        "\n",
        "\n",
        "        z1 = x1 - (grad_x1 + b*x1)/beta\n",
        "        x1_new = x1_po(z1)\n",
        "\n",
        "        z2 = x2 - (grad_x2 + b*x2)/beta\n",
        "        x2_new = x2_po(z2)\n",
        "\n",
        "        z = y +  ( grad_y - c * y ) /gamma\n",
        "        y_new = y_po(z)\n",
        "\n",
        "        t += 1\n",
        "\n",
        "\n",
        "        end = time.time()\n",
        "\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        elapsed_time += end - start\n",
        "\n",
        "        primal_gap1 = np.linalg.norm( x1_po( x1 - grad_x1/beta ) - x1 ) * beta\n",
        "        x1 = x1_new\n",
        "\n",
        "        primal_gap2 = np.linalg.norm( x2_po( x2 - grad_x2/beta ) - x2 ) * beta\n",
        "        x2 = x2_new\n",
        "\n",
        "        primal_gap = primal_gap1 + primal_gap2\n",
        "\n",
        "        dual_gap = np.linalg.norm( y_new - y )/gamma\n",
        "        y = y_new\n",
        "\n",
        "        gap.append( primal_gap + dual_gap)\n",
        "\n",
        "        # print('Iteration: {}, Primal: {}, Dual: {}, Total: {}'.format(t, primal_gap, dual_gap, primal_gap+ dual_gap))\n",
        "\n",
        "\n",
        "    df = pd.DataFrame({\n",
        "        't': iters,\n",
        "        'gap': gap,\n",
        "        'time_elapsed': time_elapsed})\n",
        "    df.to_csv(filename, index=False)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "19cbb5dc-1335-439a-b653-29463a562968",
      "metadata": {
        "id": "19cbb5dc-1335-439a-b653-29463a562968"
      },
      "outputs": [],
      "source": [
        "def SPFW(x1, x2, y, x1_lmo, x2_lmo, y_lmo, Lxx, Lyx, Lyy, T, budget):\n",
        "    filename = 'spfw.csv'\n",
        "    iters = []\n",
        "    gap = []\n",
        "    time_elapsed = []\n",
        "    oracles = []\n",
        "\n",
        "    y0 = y\n",
        "\n",
        "    elapsed_time = 0\n",
        "    t = 0\n",
        "    while elapsed_time <= budget:\n",
        "\n",
        "        start = time.time()\n",
        "\n",
        "        grad_x1, grad_x2, grad_y = gradL( x1, x2, y)\n",
        "\n",
        "        tau = 2/(t+2)\n",
        "        v1 = x1_lmo( grad_x1 )\n",
        "        x1_new = ( 1 - tau ) * x1 + tau * v1\n",
        "\n",
        "        v2 = x2_lmo( grad_x2 )\n",
        "        x2_new = ( 1 - tau ) * x2 + tau * v2\n",
        "\n",
        "\n",
        "        w = y_lmo(grad_y)\n",
        "        y_new = ( 1 - tau ) * y + tau * w\n",
        "\n",
        "        t += 1\n",
        "\n",
        "        end = time.time()\n",
        "\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        elapsed_time += end-start\n",
        "\n",
        "        primal_gap1 = abs(np.sum( grad_x1 * ( x1 -v1 ) ))\n",
        "        primal_gap2 = abs(np.sum( grad_x2 * ( x2 -v2 ) ))\n",
        "        primal_gap = primal_gap1 + primal_gap2\n",
        "\n",
        "        dual_gap = abs(grad_y * (w - y))\n",
        "\n",
        "        x1 = x1_new\n",
        "        x2 = x2_new\n",
        "\n",
        "        y = y_new\n",
        "\n",
        "\n",
        "        gap.append( primal_gap + dual_gap )\n",
        "\n",
        "        # print('Iteration: {}, Primal: {}, Dual: {}, Total: {}'.format(t, primal_gap, dual_gap, primal_gap+ dual_gap))\n",
        "\n",
        "\n",
        "    df = pd.DataFrame({\n",
        "        't': iters,\n",
        "        'gap': gap,\n",
        "        'time_elapsed': time_elapsed})\n",
        "    df.to_csv(filename, index=False)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "5d572fb2-e1f5-4046-9e46-496b51b0bdd5",
      "metadata": {
        "id": "5d572fb2-e1f5-4046-9e46-496b51b0bdd5"
      },
      "outputs": [],
      "source": [
        "def gradL(x1, x2 ,y):\n",
        "\n",
        "    grad_x1 = -(A_new - x1 @ x2 ) @ x2.T / nv - y * ( A_old - x1 @ C) @ C.T / n\n",
        "    grad_x2 = -x1.T @ (A_new - x1 @ x2 ) / nv\n",
        "    grad_y = np.linalg.norm( A_old - x1 @ C )**2 / (2*n) - delta\n",
        "\n",
        "    return grad_x1, grad_x2, grad_y\n",
        "\n",
        "from scipy.linalg import eigh\n",
        "from scipy.linalg import eigvals\n",
        "\n",
        "def x1_lmo(c1):\n",
        "\n",
        "    norms = np.linalg.norm(c1, axis = 0)\n",
        "\n",
        "    return -c1 / norms.reshape(1, -1)\n",
        "\n",
        "def x2_lmo(c2):\n",
        "    u, s, vt = svds(c2, k=1)\n",
        "\n",
        "    return -r * (u @ vt)\n",
        "\n",
        "def x1_po(c1):\n",
        "\n",
        "    norms = np.linalg.norm( c1 , axis = 0)\n",
        "    scales = np.maximum( norms , 1)\n",
        "\n",
        "    return c1 / scales.reshape(1, -1)\n",
        "\n",
        "\n",
        "def simplex_projection(s):\n",
        "    \"\"\"Projection onto the unit simplex.\"\"\"\n",
        "    if np.sum(s) <=1 and np.all(s >= 0):\n",
        "        return s\n",
        "\n",
        "    u = np.sort(s)[::-1]\n",
        "    cssv = np.cumsum(u)\n",
        "    rho = np.nonzero(u * np.arange(1, len(u)+1) > (cssv - 1))[0][-1]\n",
        "    theta = (cssv[rho] - 1) / (rho + 1.0)\n",
        "\n",
        "    return np.maximum(s-theta, 0)\n",
        "\n",
        "def nuclear_projection(A):\n",
        "    \"\"\"Projection onto nuclear norm ball.\"\"\"\n",
        "    U, s, V = np.linalg.svd(A, full_matrices=False)\n",
        "    s = simplex_projection(s)\n",
        "    return U.dot(np.diag(s).dot(V))\n",
        "\n",
        "def x2_po(c2):\n",
        "\n",
        "    return nuclear_projection(c2/r)*r\n",
        "\n",
        "def y_lmo(c3):\n",
        "\n",
        "    return (np.sign(c3)+1)*B/2\n",
        "\n",
        "\n",
        "def y_po(c3):\n",
        "\n",
        "    return max(0,min(B,c3))\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "2be95e50-36d0-449d-91e0-7919bb5b059e",
      "metadata": {
        "id": "2be95e50-36d0-449d-91e0-7919bb5b059e"
      },
      "outputs": [],
      "source": [
        "X1_init = np.random.uniform(low=0, high=0.1, size=(m, q))\n",
        "X1_init = X1_init/np.linalg.norm( X1_init , axis = 0 ).reshape(1,-1)\n",
        "X2_init = np.random.uniform(low=0, high=0.1, size=(q, nv))\n",
        "X2_init = r*X2_init/np.linalg.norm(X2_init, ord = 'nuc')\n",
        "y0 = 0\n",
        "T = 10**3"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "ba7f81f0-b6dd-4359-a05a-6ec83fbe329e",
      "metadata": {
        "id": "ba7f81f0-b6dd-4359-a05a-6ec83fbe329e"
      },
      "outputs": [],
      "source": [
        "norm1  = np.linalg.norm(A_new)\n",
        "norm2 = np.linalg.norm(C, ord=2)\n",
        "term1 = (2*( norm1 + 2*r*q**0.5 )**2/nv**2 + 3*( r**2/nv + B* norm2**2/n )**2)**0.5\n",
        "term2 = (2*q**2 + 3*( norm1 + 2*r*q**0.5 )**2)**0.5/nv\n",
        "Lyy = 0\n",
        "Lyx = 3**0.5 * ( norm1 + q**0.5 * norm2) * norm2/n\n",
        "Lxx = max(term1, term2)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "0aec5d34-67eb-47e8-82ba-32e65680b653",
      "metadata": {
        "id": "0aec5d34-67eb-47e8-82ba-32e65680b653"
      },
      "outputs": [],
      "source": [
        "tau1 = 1/T**(5/6)\n",
        "mu1 = 0.01/T**(1/6)\n",
        "\n",
        "tau2 = 1/T**(3/4)\n",
        "mu2 = 0.01/T**(1/4)\n",
        "sigma = 2 / ( Lyy + 2 * mu2 )\n",
        "alpha = 1/B\n",
        "\n",
        "rho_bar = 0.05\n",
        "eta_bar = 0.05\n",
        "tau = 2*max( 19**2*(Lxx+2*eta_bar-rho_bar*Lyx**2)/(20*17*rho_bar*Lyx**2),2)\n",
        "\n",
        "\n",
        "a1 = 4/5\n",
        "b1 = 1/5\n",
        "a2 = 3/4\n",
        "b2 = 1/4\n",
        "a3 = 3/5\n",
        "b3 = 1/5\n",
        "\n",
        "budget = 300"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "d1d5cbad-9f75-4059-816c-de8a579d9c4c",
      "metadata": {
        "scrolled": true,
        "id": "d1d5cbad-9f75-4059-816c-de8a579d9c4c"
      },
      "outputs": [],
      "source": [
        "LMO_LMO(X1_init , X2_init , y0, x1_lmo, x2_lmo, y_lmo, Lyy, a1, b1, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "5fbd6e86-eccf-43ff-802e-6cad228c9432",
      "metadata": {
        "scrolled": true,
        "id": "5fbd6e86-eccf-43ff-802e-6cad228c9432"
      },
      "outputs": [],
      "source": [
        "LMO_PO(X1_init , X2_init , y0, x1_lmo, x2_lmo, y_po, Lyy, a2, b2, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "cee14ac4-4e31-44d1-ac67-31094d0c33b5",
      "metadata": {
        "scrolled": true,
        "id": "cee14ac4-4e31-44d1-ac67-31094d0c33b5"
      },
      "outputs": [],
      "source": [
        "PO_LMO(X1_init , X2_init , y0, x1_po, x2_po, y_lmo, Lyy, Lyx, Lxx, a3, b3, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "380c6fc3-c97a-40ca-8ef5-b626ca0da2d2",
      "metadata": {
        "scrolled": true,
        "id": "380c6fc3-c97a-40ca-8ef5-b626ca0da2d2"
      },
      "outputs": [],
      "source": [
        "R_PDCG(X1_init , X2_init , y0, x1_lmo, x2_lmo, y_lmo, Lyy, tau1, mu1, alpha, T, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "5cfa77e6-f8de-4ada-ac13-506b6c6906c4",
      "metadata": {
        "scrolled": true,
        "id": "5cfa77e6-f8de-4ada-ac13-506b6c6906c4"
      },
      "outputs": [],
      "source": [
        "CG_RPGA(X1_init , X2_init , y0, x1_lmo, x2_lmo, y_po, Lyy, tau2, mu2, sigma, T, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "be77c843-0c1c-43af-9981-b482c3411a79",
      "metadata": {
        "scrolled": true,
        "id": "be77c843-0c1c-43af-9981-b482c3411a79"
      },
      "outputs": [],
      "source": [
        "AGP(X1_init , X2_init , y0, x1_po, x2_po, y_po, tau, eta_bar, rho_bar, Lxx, Lyx, Lyy, T, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "0cb43578-15d7-4b52-945e-fde9bfb5aa4c",
      "metadata": {
        "scrolled": true,
        "id": "0cb43578-15d7-4b52-945e-fde9bfb5aa4c"
      },
      "outputs": [],
      "source": [
        "SPFW(X1_init , X2_init , y0, x1_lmo, x2_lmo, y_lmo, Lxx, Lyx, Lyy, T, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "e64d135a-8f17-4e43-83c2-d6a6584ce643",
      "metadata": {
        "id": "e64d135a-8f17-4e43-83c2-d6a6584ce643"
      },
      "outputs": [],
      "source": []
    }
  ],
  "metadata": {
    "kernelspec": {
      "display_name": "Python [conda env:base] *",
      "language": "python",
      "name": "conda-base-py"
    },
    "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.12.7"
    },
    "colab": {
      "provenance": []
    }
  },
  "nbformat": 4,
  "nbformat_minor": 5
}