{
  "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": "0c5306c6-51ac-4d6e-92e6-73aac5257635",
      "metadata": {
        "id": "0c5306c6-51ac-4d6e-92e6-73aac5257635"
      },
      "outputs": [],
      "source": [
        "from sklearn.datasets import load_svmlight_file\n",
        "A, b = load_svmlight_file(\"rcv1_train.multiclass\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "04f60f69-c861-4e2c-beb1-2491bc960e7d",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "04f60f69-c861-4e2c-beb1-2491bc960e7d",
        "outputId": "456127b2-95fb-4b11-cefc-fd9b414daee9"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(15564, 47236)"
            ]
          },
          "metadata": {},
          "execution_count": 3
        }
      ],
      "source": [
        "A.shape"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "8f09a8dd-347e-4ce9-9cec-54e1635fecb2",
      "metadata": {
        "id": "8f09a8dd-347e-4ce9-9cec-54e1635fecb2"
      },
      "outputs": [],
      "source": [
        "n = 15564\n",
        "d = 47236\n",
        "k = 53\n",
        "# rho = 1.5\n",
        "# r = 5\n",
        "r = 10\n",
        "lbd = 10"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "3528f614-1c8d-4fc9-a172-70aaae21c207",
      "metadata": {
        "id": "3528f614-1c8d-4fc9-a172-70aaae21c207"
      },
      "outputs": [],
      "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",
        "\n",
        "        dual_gap = np.sum( grad_y * ( u - y ) )\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",
        "        x = x_new\n",
        "        y = y_new\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(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",
        "\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        elapsed_time += end - start\n",
        "\n",
        "\n",
        "\n",
        "        primal_gap = np.sum( grad_x * ( x - v ) )\n",
        "\n",
        "        dual_gap = np.linalg.norm( y_new   - y )/gamma\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",
        "        x = x_new\n",
        "        y = y_new\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(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",
        "\n",
        "\n",
        "        primal_gap = np.linalg.norm( x - x_new  ) / tau\n",
        "\n",
        "\n",
        "        dual_gap = np.sum( grad_y * ( u - y ) )\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",
        "        x = x_new\n",
        "        y = y_new\n",
        "\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(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",
        "\n",
        "\n",
        "        primal_gap = np.sum( grad_x * ( x - v ) )\n",
        "\n",
        "\n",
        "        dual_gap = np.sum( grad_y * (u - 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",
        "        x = x_new\n",
        "        y = y_new\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(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",
        "\n",
        "\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        elapsed_time += end - start\n",
        "\n",
        "\n",
        "\n",
        "        primal_gap = np.sum( grad_x * ( x - v ) )\n",
        "\n",
        "        dual_gap = np.linalg.norm( y_new - y )/sigma\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",
        "        x = x_new\n",
        "        y = y_new\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": "d1ae7821-be15-4599-8fc3-0261b50e7fc3",
      "metadata": {
        "id": "d1ae7821-be15-4599-8fc3-0261b50e7fc3"
      },
      "outputs": [],
      "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",
        "\n",
        "\n",
        "\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        elapsed_time += end - start\n",
        "\n",
        "\n",
        "\n",
        "        primal_gap = np.linalg.norm( x_new - x ) * beta\n",
        "\n",
        "        dual_gap = np.linalg.norm( y_new - y )*gamma\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",
        "        x = x_new\n",
        "        y = y_new\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": "764d76fb-ef1e-4abd-b77f-9c15f9e17d7e",
      "metadata": {
        "id": "764d76fb-ef1e-4abd-b77f-9c15f9e17d7e"
      },
      "outputs": [],
      "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",
        "\n",
        "        iters.append(t)\n",
        "        time_elapsed.append(elapsed_time)\n",
        "\n",
        "        elapsed_time += end-start\n",
        "        primal_gap = np.sum( grad_x * ( x -v ) )\n",
        "        dual_gap = np.sum( grad_y * (w - y) )\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",
        "        x = x_new\n",
        "        y = y_new\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": "zm1I5lgbHSdS",
      "metadata": {
        "id": "zm1I5lgbHSdS"
      },
      "outputs": [],
      "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)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "5d572fb2-e1f5-4046-9e46-496b51b0bdd5",
      "metadata": {
        "id": "5d572fb2-e1f5-4046-9e46-496b51b0bdd5"
      },
      "outputs": [],
      "source": [
        "from scipy.linalg import eigh\n",
        "from scipy.linalg import eigvals\n",
        "from scipy.sparse.linalg import svds\n",
        "\n",
        "\n",
        "\n",
        "def x_lmo(c):\n",
        "    u, s, vt = svds(c, k=1)\n",
        "\n",
        "    return -r * (u @ vt)\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",
        "\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))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "929107f1-4c20-4454-abed-0df533d2d812",
      "metadata": {
        "id": "929107f1-4c20-4454-abed-0df533d2d812"
      },
      "outputs": [],
      "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)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "2be95e50-36d0-449d-91e0-7919bb5b059e",
      "metadata": {
        "id": "2be95e50-36d0-449d-91e0-7919bb5b059e"
      },
      "outputs": [],
      "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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "ba7f81f0-b6dd-4359-a05a-6ec83fbe329e",
      "metadata": {
        "id": "ba7f81f0-b6dd-4359-a05a-6ec83fbe329e"
      },
      "outputs": [],
      "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()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "0aec5d34-67eb-47e8-82ba-32e65680b653",
      "metadata": {
        "id": "0aec5d34-67eb-47e8-82ba-32e65680b653"
      },
      "outputs": [],
      "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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "d1d5cbad-9f75-4059-816c-de8a579d9c4c",
      "metadata": {
        "id": "d1d5cbad-9f75-4059-816c-de8a579d9c4c"
      },
      "outputs": [],
      "source": [
        "LMO_LMO(X_init, y0, x_lmo, y_lmo, Lyy, a1, b1, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "5fbd6e86-eccf-43ff-802e-6cad228c9432",
      "metadata": {
        "id": "5fbd6e86-eccf-43ff-802e-6cad228c9432",
        "scrolled": true
      },
      "outputs": [],
      "source": [
        "LMO_PO(X_init, y0, x_lmo, y_po, Lyy, a2, b2, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "cee14ac4-4e31-44d1-ac67-31094d0c33b5",
      "metadata": {
        "id": "cee14ac4-4e31-44d1-ac67-31094d0c33b5",
        "scrolled": true
      },
      "outputs": [],
      "source": [
        "PO_LMO(X_init, y0, x_po, y_lmo, Lyy, Lyx, Lxx, a3, b3, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "380c6fc3-c97a-40ca-8ef5-b626ca0da2d2",
      "metadata": {
        "id": "380c6fc3-c97a-40ca-8ef5-b626ca0da2d2",
        "scrolled": true
      },
      "outputs": [],
      "source": [
        "CG_RPGA(X_init, y0, x_lmo, y_po, Lyy, tau2, mu2, sigma, T, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "251c77ee-3b1f-4414-93a6-2d57de62ce67",
      "metadata": {
        "id": "251c77ee-3b1f-4414-93a6-2d57de62ce67"
      },
      "outputs": [],
      "source": [
        "AGP(X_init, y0, x_po, y_po, tau, eta_bar, rho_bar, Lxx, Lyx, Lyy, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "12740130-18e0-439a-8204-507ff3d8d8b4",
      "metadata": {
        "id": "12740130-18e0-439a-8204-507ff3d8d8b4"
      },
      "outputs": [],
      "source": [
        "SPFW(X_init, y0, x_lmo, y_lmo, Lxx, Lyx, Lyy, budget)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "e64d135a-8f17-4e43-83c2-d6a6584ce643",
      "metadata": {
        "id": "e64d135a-8f17-4e43-83c2-d6a6584ce643"
      },
      "outputs": [],
      "source": []
    }
  ],
  "metadata": {
    "colab": {
      "provenance": []
    },
    "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"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 5
}