{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "JGFt95IV91o5"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import time\n",
        "import pandas as pd\n",
        "import csv"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "from sklearn.datasets import load_svmlight_file\n",
        "A, b = load_svmlight_file(\"news20\")\n",
        "\n",
        "print(f\"Number of documents: {A.shape[0]}\")\n",
        "print(f\"Number of unique words: {A.shape[1]}\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "QErUnwoO9-2a",
        "outputId": "a20670cb-1347-4793-a4a1-d9baa81e81cb"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Number of documents: 15935\n",
            "Number of unique words: 62061\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "n = 15935\n",
        "d = 62061\n",
        "k = 20\n",
        "# rho = 0.15\n",
        "r = 10\n",
        "lbd = 10"
      ],
      "metadata": {
        "id": "klrPa_Jb-EeV"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def LMO_LMO(x, y, x_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",
        "\n",
        "\n",
        "        grad_x, grad_y = gradL( x, y)\n",
        "\n",
        "        v = x_lmo( grad_x )\n",
        "        x_new = ( 1 - tau ) * x + tau * v\n",
        "\n",
        "        u = y_lmo( grad_y )\n",
        "        gamma = min( 1 , np.sum( grad_y* ( u - y )) / ( Lyy * np.linalg.norm( u - y )**2 ) )\n",
        "        y_new = ( 1 - gamma ) * y + gamma * u\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_gap = np.sum( grad_x *( x - v ) )\n",
        "        x = x_new\n",
        "\n",
        "        dual_gap = np.sum( grad_y * ( u - y ) )\n",
        "        y = y_new\n",
        "\n",
        "        # if elapsed_time%30< 1:\n",
        "\n",
        "        gap.append( primal_gap + dual_gap)\n",
        "\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)"
      ],
      "metadata": {
        "id": "rGFjCB-F-E1O"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def LMO_PO(x, y, x_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",
        "\n",
        "        gamma = 1 / Lyy\n",
        "\n",
        "        grad_x, grad_y = gradL( x, y)\n",
        "\n",
        "        v = x_lmo( grad_x )\n",
        "        x_new = ( 1 - tau ) * x + tau * v\n",
        "\n",
        "        y_new = y_po( y + gamma * grad_y )\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_gap = np.sum( grad_x * ( x - v ) )\n",
        "        x = x_new\n",
        "\n",
        "        dual_gap = np.linalg.norm( y_new   - y )/gamma\n",
        "        y = y_new\n",
        "\n",
        "        # if elapsed_time%30< 1:\n",
        "\n",
        "\n",
        "        gap.append( primal_gap + dual_gap)\n",
        "\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)"
      ],
      "metadata": {
        "id": "c2oRwjzi-GDb"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def PO_LMO(x, y, x_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",
        "\n",
        "        tau = 1000/ ( t + 1 )**a\n",
        "\n",
        "\n",
        "        grad_x, grad_y = gradL( x, y)\n",
        "\n",
        "        x_new = x_po( x - tau * grad_x )\n",
        "\n",
        "        u = y_lmo( grad_y )\n",
        "        gamma = min( 1 , np.sum( grad_y * ( u - y ) ) / ( Lyy * np.linalg.norm( u - y )**2 ) )\n",
        "        y_new = ( 1 - gamma ) * y + gamma * u\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_gap = np.linalg.norm( x - x_new  ) / tau\n",
        "        x = x_new\n",
        "\n",
        "        dual_gap = np.sum( grad_y * ( u - y ) )\n",
        "        y = y_new\n",
        "\n",
        "        # if elapsed_time%30< 1:\n",
        "\n",
        "\n",
        "        gap.append( primal_gap + dual_gap)\n",
        "\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)"
      ],
      "metadata": {
        "id": "YQGbaSSA-HeK"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def R_PDCG(x, y, x_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_x, grad_y = gradL( x, y)\n",
        "\n",
        "        v = x_lmo( grad_x )\n",
        "        x_new = ( 1 - tau ) * x + tau * v\n",
        "\n",
        "        u = y_lmo( grad_y )\n",
        "        gamma = min (1 , alpha * np.linalg.norm( grad_y ) / ( 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_gap = np.sum( grad_x * ( x - v ) )\n",
        "        x = x_new\n",
        "\n",
        "        dual_gap = np.sum( grad_y * (u - y) )\n",
        "        y = y_new\n",
        "\n",
        "        # if elapsed_time%30< 1:\n",
        "\n",
        "\n",
        "        gap.append( primal_gap + dual_gap)\n",
        "\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)\n"
      ],
      "metadata": {
        "id": "gHaJaJwO-IyE"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def CG_RPGA(x, y, x_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",
        "        grad_x, grad_y = gradL( x, y)\n",
        "\n",
        "        v = x_lmo( grad_x )\n",
        "        x_new = ( 1 - tau ) * x + tau * v\n",
        "\n",
        "        y_new = y_po( y + sigma *  grad_y  )\n",
        "\n",
        "\n",
        "        t += 1\n",
        "\n",
        "\n",
        "        end = time.time()\n",
        "\n",
        "        iters.append(t)\n",
        "\n",
        "        elapsed_time += end - start\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        primal_gap = np.sum( grad_x * ( x - v ) )\n",
        "        x = x_new\n",
        "\n",
        "        dual_gap = np.linalg.norm( y_new - y )/sigma\n",
        "        y = y_new\n",
        "\n",
        "        # if elapsed_time%30< 1:\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",
        "    df = pd.DataFrame({\n",
        "        't': iters,\n",
        "        'gap': gap,\n",
        "        'time_elapsed': time_elapsed})\n",
        "    df.to_csv(filename, index=False)"
      ],
      "metadata": {
        "id": "USAD9SNG-KR3"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def AGP(x, y, x_po, y_po, tau, eta_bar, rho_bar, Lxx, Lyx, Lyy, 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_x, grad_y = gradL( x, y)\n",
        "\n",
        "\n",
        "        beta = eta_bar\n",
        "        gamma = 1/rho_bar\n",
        "\n",
        "        x_new = x_po(x - grad_x/beta)\n",
        "\n",
        "        y_new = y_po(y +  grad_y  /gamma)\n",
        "\n",
        "        t += 1\n",
        "\n",
        "\n",
        "        end = time.time()\n",
        "        elapsed_time += end - start\n",
        "\n",
        "        primal_gap = np.linalg.norm( x_new - x ) * beta\n",
        "        x = x_new\n",
        "\n",
        "        dual_gap = np.linalg.norm( y_new - y )*gamma\n",
        "        y = y_new\n",
        "\n",
        "        # if elapsed_time%30< 1:\n",
        "\n",
        "        iters.append(t)\n",
        "        gap.append( primal_gap + dual_gap)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        # print('Iteration: {}, Primal: {}, Dual: {}, Total: {}'.format(t, primal_gap, dual_gap, primal_gap+ dual_gap))\n",
        "\n",
        "    df = pd.DataFrame({\n",
        "        't': iters,\n",
        "        'gap': gap,\n",
        "        'time_elapsed': time_elapsed})\n",
        "    df.to_csv(filename, index=False)"
      ],
      "metadata": {
        "id": "SvpEZf3r-LoV"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def SPFW(x, y, x_lmo, y_lmo, Lxx, Lyx, Lyy, 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_x, grad_y = gradL( x, y)\n",
        "\n",
        "        tau = 2/(t+2)\n",
        "        v = x_lmo( grad_x )\n",
        "        x_new = ( 1 - tau ) * x + tau * v\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",
        "        elapsed_time += end-start\n",
        "\n",
        "        primal_gap = np.sum( grad_x * ( x -v ) )\n",
        "        dual_gap = np.sum( grad_y * (w - y) )\n",
        "\n",
        "        x = x_new\n",
        "        y = y_new\n",
        "\n",
        "        # if elapsed_time%30< 1:\n",
        "\n",
        "        iters.append(t)\n",
        "        gap.append( primal_gap + dual_gap)\n",
        "        time_elapsed.append(elapsed_time)\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)"
      ],
      "metadata": {
        "id": "B0SRlIso-NMA"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "from scipy.sparse import csr_matrix, isspmatrix_coo\n",
        "\n",
        "b_idx = b.astype(int) - 1\n",
        "\n",
        "def gradL(x, y):\n",
        "\n",
        "    x_sum = x.sum(axis=0)\n",
        "    A_dot_sum = A.dot(x_sum)\n",
        "\n",
        "\n",
        "    A_dot_x_idx = np.asarray(A.multiply(x[b_idx]).sum(axis=1)).flatten()\n",
        "\n",
        "    dot_vals = A_dot_sum - k * A_dot_x_idx\n",
        "    exp = np.exp(dot_vals)\n",
        "    grad_y = np.log1p(exp)\n",
        "    weights = (y * exp/ (1 + exp))\n",
        "\n",
        "\n",
        "    weighted_A = A.multiply(weights.reshape(-1, 1)).tocsr()\n",
        "\n",
        "\n",
        "    sum_weighted_A = np.asarray(weighted_A.sum(axis=0))\n",
        "    grad_x = np.tile(sum_weighted_A, (k, 1))\n",
        "\n",
        "\n",
        "    correction = np.zeros((k, d))\n",
        "\n",
        "\n",
        "    for i in range(n):\n",
        "        row_idx = b_idx[i]\n",
        "        start, end = weighted_A.indptr[i], weighted_A.indptr[i+1]\n",
        "        correction[row_idx, weighted_A.indices[start:end]] += weighted_A.data[start:end]\n",
        "\n",
        "    grad_x -= k * correction\n",
        "\n",
        "    return grad_x/n, grad_y/n - lbd* (y- 1/n)"
      ],
      "metadata": {
        "id": "i83X1uSI-OeH"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "from scipy.linalg import eigh\n",
        "from scipy.linalg import eigvals\n",
        "from scipy.sparse.linalg import svds\n",
        "\n",
        "# def x_lmo(c):\n",
        "\n",
        "#     spec, left = eigh( c @ c.T, subset_by_index=[k-1,k-1])\n",
        "#     right = c.T@left/np.sqrt(spec)\n",
        "\n",
        "#     return -r*left@right.T\n",
        "\n",
        "def x_lmo(c):\n",
        "    # k=1 gets only the leading singular value/vectors\n",
        "    # svds avoids c2 @ c2.T and uses Lanczos iterations instead\n",
        "    u, s, vt = svds(c, k=1)\n",
        "\n",
        "    # -r * u @ v^T (Note: vt is already V.T)\n",
        "    return -r * (u @ vt)\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",
        "\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 x_po(c):\n",
        "    \"\"\"Projection onto nuclear norm ball.\"\"\"\n",
        "    U, s, V = np.linalg.svd(c / r, full_matrices=False)\n",
        "    s = simplex_projection(s)\n",
        "    return r*U.dot(np.diag(s).dot(V))"
      ],
      "metadata": {
        "id": "nufNTXgG-QL9"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def y_lmo(c3):\n",
        "    u = np.zeros(n)\n",
        "    u[np.argmax(c3)] = 1\n",
        "    return u\n",
        "\n",
        "def y_po(c3):\n",
        "\n",
        "    D = len(c3)\n",
        "    u = np.sort(c3)[::-1]\n",
        "\n",
        "    cssv = np.cumsum(u)\n",
        "    indices = np.arange(1, D + 1)\n",
        "    condition = u + (1.0 / indices) * (1.0 - cssv) > 0\n",
        "\n",
        "    rho = np.where(condition)[0][-1]\n",
        "    theta = (1.0 / (rho + 1)) * (1.0 - cssv[rho])\n",
        "\n",
        "    return np.maximum(c3 + theta, 0)"
      ],
      "metadata": {
        "id": "Mnzpf2-j-Rh-"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "X_init = np.random.uniform(low=1, high=5, size=(k, d))\n",
        "X_init = r*X_init/np.linalg.norm(X_init, ord = 'nuc')\n",
        "X_init = np.zeros((k,d))\n",
        "y0 = np.random.uniform(low=0, high=1, size=(n, 1)).reshape(-1)\n",
        "y0= y0/sum(y0)\n",
        "y0 = np.ones(n)/n\n",
        "T = 10**4"
      ],
      "metadata": {
        "id": "psH2_3gG-Szo"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "from scipy.sparse import linalg\n",
        "\n",
        "Lyy = np.sqrt(2)*lbd\n",
        "Lyx = np.sqrt( k*(k-1)/2) * linalg.norm(A)\n",
        "Lxx = ( k*(k-1)/4 )*A.power(2).sum(axis=1).max()"
      ],
      "metadata": {
        "id": "wPa6DcbL-ULe"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "tau1 = 10/T**(3/4)\n",
        "mu1 = 0\n",
        "\n",
        "tau2 = 10/T**(1/2)\n",
        "mu2 = 0\n",
        "sigma = 2 / ( Lyy + lbd )\n",
        "\n",
        "mu = lbd\n",
        "rho_bar = mu / (2*Lyy)**2\n",
        "\n",
        "eta_bar = max(Lyx**2*rho_bar +(2*Lyx)**2/(rho_bar*mu**2), Lxx)*2\n",
        "tau = 2*max( 19**2*(Lxx+2*eta_bar-rho_bar*Lyx**2)/(20*17*rho_bar*Lyx**2),2)\n",
        "\n",
        "a1 = 1\n",
        "b1 = 0\n",
        "a2 = 1\n",
        "b2 = 0\n",
        "a3 = 1/2\n",
        "b3 = 0\n",
        "\n",
        "budget = 60*15"
      ],
      "metadata": {
        "id": "TEoZa5qm-VIv"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "LMO_LMO(X_init, y0, x_lmo, y_lmo, Lyy, a1, b1, budget)"
      ],
      "metadata": {
        "id": "3Msbpnpk-WhY"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "LMO_PO(X_init, y0, x_lmo, y_po, Lyy, a2, b2, budget)"
      ],
      "metadata": {
        "id": "V0RsOWcV-XyM"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "PO_LMO(X_init, y0, x_po, y_lmo, Lyy, Lyx, Lxx, a3, b3, budget)"
      ],
      "metadata": {
        "id": "iKht-KiS-ZAo"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "CG_RPGA(X_init, y0, x_lmo, y_po, Lyy, tau2, mu2, sigma, T, budget)"
      ],
      "metadata": {
        "id": "X7aDtbq7-aIL"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "AGP(X_init, y0, x_po, y_po, tau, eta_bar, rho_bar, Lxx, Lyx, Lyy, budget)"
      ],
      "metadata": {
        "id": "Ber-ovp2-bZd"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "SPFW(X_init, y0, x_lmo, y_lmo, Lxx, Lyx, Lyy, budget)"
      ],
      "metadata": {
        "id": "58lNksR6-eTe"
      },
      "execution_count": null,
      "outputs": []
    }
  ]
}