{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {},
      "source": [
        "# NeurIPS 2025 Experiment Notebook\n",
        "This notebook contains the experiments for reproducing results in the paper submission.\n",
        "Please run the notebook from top to bottom to reproduce the figure in Appendix A from the paper."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {},
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "from scipy.optimize import minimize"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "CB3fbntwpcxw"
      },
      "source": [
        "# projection functions"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "M_n1-OMFpcx7"
      },
      "outputs": [],
      "source": [
        "def lp_ball_projection(x, p=2, radius=1):\n",
        "    \"\"\"\n",
        "    Project a point onto an L^p ball using the L^p distance.\n",
        "\n",
        "    Parameters:\n",
        "        x (array_like): The point to be projected.\n",
        "        p (float, optional): The order of the norm defining the L^p ball (default is 2).\n",
        "        radius (float, optional): The radius of the L^p ball (default is 1).\n",
        "\n",
        "    Returns:\n",
        "        array_like: The point resulting from projecting `x` onto the L^p ball.\n",
        "    \"\"\"\n",
        "    \n",
        "    def objective(z):\n",
        "        # Objective: minimize the lp norm distance between z and x\n",
        "        return np.sum(z * (np.sign(z) * np.abs(z)**(p-1) / p - np.sign(x) * np.abs(x)**(p-1)))\n",
        "\n",
        "    # Initial guess for the optimizer — start from the origin or zero vector of the same shape as x\n",
        "    initial_guess = np.zeros_like(x)\n",
        "\n",
        "    # Define the constraint: the L^p norm of the point z must be less than or equal to `radius`\n",
        "    constraint = {'type': 'ineq', 'fun': lambda z: radius - np.linalg.norm(z, ord=p)}\n",
        "\n",
        "    # Use the SLSQP optimizer to minimize the objective subject to the L^p norm constraint\n",
        "    result = minimize(objective, initial_guess, method='SLSQP', constraints=[constraint])\n",
        "\n",
        "    # Return the optimized point, i.e., the projection of x onto the L^p ball\n",
        "    return result.x"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "3Ot1L876pcx-"
      },
      "outputs": [],
      "source": [
        "def l2_projection_onto_lp_ball(x, p=2, radius=1):\n",
        "    \"\"\"\n",
        "    Project a point onto an L^p ball using the L^2 (Euclidean) distance.\n",
        "\n",
        "    Parameters:\n",
        "        x (array_like): The point to be projected.\n",
        "        p (float, optional): The order of the norm defining the L^p ball (default is 2).\n",
        "        radius (float, optional): The radius of the L^p ball (default is 1).\n",
        "\n",
        "    Returns:\n",
        "        array_like: The point resulting from projecting `x` onto the L^p ball.\n",
        "    \"\"\"\n",
        "    \n",
        "    def objective(z):\n",
        "        # Objective: minimize the Euclidean (L^2) distance between z and x\n",
        "        return np.linalg.norm(x - z, ord=2)\n",
        "\n",
        "    # Initial guess for the optimizer — start from the origin or zero vector of the same shape as x\n",
        "    initial_guess = np.zeros_like(x)\n",
        "\n",
        "    # Define the constraint: the L^p norm of the point z must be less than or equal to `radius`\n",
        "    constraint = {'type': 'ineq', 'fun': lambda z: radius - np.linalg.norm(z, ord=p)}\n",
        "\n",
        "    # Use the SLSQP optimizer to minimize the objective subject to the L^p norm constraint\n",
        "    result = minimize(objective, initial_guess, method='SLSQP', constraints=[constraint])\n",
        "\n",
        "    # Return the projected point\n",
        "    return result.x"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "u4P4aj8HpcyB"
      },
      "outputs": [],
      "source": [
        "def competitor(G, p=2, radius=1):\n",
        "    \"\"\"\n",
        "    Find the optimal point of an online linear optimization problem where the sum of the costs is G\n",
        "\n",
        "    Specifically, this function finds the point z within the L^p ball of the given\n",
        "    radius that minimizes the linear objective ⟨G, z⟩ (i.e., dot product of G and z).\n",
        "\n",
        "    Parameters:\n",
        "        G (array_like): cumulative cost vector.\n",
        "        p (float, optional): Order of the norm defining the L^p ball (default is 2).\n",
        "        radius (float, optional): Radius of the L^p ball (default is 1).\n",
        "\n",
        "    Returns:\n",
        "        array_like: The point z in the L^p ball that minimizes ⟨G, z⟩.\n",
        "    \"\"\"\n",
        "    \n",
        "    def objective(z):\n",
        "        # Linear objective: minimize the inner product between G and z\n",
        "        return np.sum(G * z)\n",
        "\n",
        "    # Start from the origin or zero vector\n",
        "    initial_guess = np.zeros_like(G)\n",
        "\n",
        "    # Define constraint: z must lie within the L^p ball of given radius\n",
        "    constraint = {\n",
        "        'type': 'ineq',\n",
        "        'fun': lambda z: radius - np.linalg.norm(z, ord=p)\n",
        "    }\n",
        "\n",
        "    # Minimize the linear objective subject to the norm constraint using SLSQP\n",
        "    result = minimize(objective, initial_guess, method='SLSQP', constraints=[constraint])\n",
        "\n",
        "    return result.x"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "H7Asm4gKz6NH"
      },
      "source": [
        "# Algorithms"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "c__u6zP8Emsi"
      },
      "outputs": [],
      "source": [
        "# This runs the FTRL with adaptive regularization and threshold t0 (Section 3)\n",
        "def FTRL_opt(d, T, p, t0):\n",
        "  a = np.array([0 for i in range(d)])\n",
        "  Losses = np.zeros([d,T])\n",
        "  Regret = 0\n",
        "  x = np.array([1/(d**((p-1)/p)) for i in range(d)])\n",
        "  e1 = np.array([0 for i in range(d)])\n",
        "  e1[0] = 1\n",
        "  q = p/(p-1)\n",
        "\n",
        "  for t in range(T):\n",
        "    x = np.array([1/(d**((p-1)/p)) for i in range(d)])\n",
        "    if t < T/2:\n",
        "      x = (-1)**(t+1) * e1\n",
        "    Losses[:,t] = x\n",
        "    Regret += sum(a*x)\n",
        "\n",
        "    if t+1 < t0:\n",
        "      eta = 1/(2*q*(t+1))**(1/q)\n",
        "      G = - eta * Losses.sum(axis = 1)\n",
        "      a = np.sign(G)*(np.abs(G)**(q-1))\n",
        "      a = lp_ball_projection(a, p, 1)\n",
        "    else:\n",
        "      eta = np.sqrt(d**(1-2/p) / (2*(t+1)))\n",
        "      G = - eta * Losses.sum(axis = 1)\n",
        "      a = l2_projection_onto_lp_ball(G, p, 1)\n",
        "  G = Losses.sum(axis = 1)\n",
        "  comp = competitor(G, p = p)\n",
        "  Regret = Regret - np.sum(G*comp)\n",
        "  print(Regret)\n",
        "  return(Regret)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "5ibAnZ5vGAcJ"
      },
      "outputs": [],
      "source": [
        "# This runs the FTRL with regualrizer psi_p(x) = \\norm{x}_p^p / p (Section 2.3)\n",
        "def FTRL_psip(d, T, p):\n",
        "  a = np.array([0 for i in range(d)])\n",
        "  Losses = np.zeros([d,T])\n",
        "  Regret = 0\n",
        "  x = np.array([1/(d**((p-1)/p)) for i in range(d)])\n",
        "  e1 = np.array([0 for i in range(d)])\n",
        "  e1[0] = 1\n",
        "  q = p/(p-1)\n",
        "\n",
        "  for t in range(T):\n",
        "    x = np.array([1/(d**((p-1)/p)) for i in range(d)])\n",
        "    if t < T/2:\n",
        "      x = (-1)**(t+1) * e1\n",
        "    Losses[:,t] = x\n",
        "    Regret += sum(a*x)\n",
        "\n",
        "    eta = 1/(2*q*(t+1))**(1/q)\n",
        "    G = - eta * Losses.sum(axis = 1)\n",
        "    a = np.sign(G)*(np.abs(G)**(q-1))\n",
        "    a = lp_ball_projection(a, p, 1)\n",
        "  G = Losses.sum(axis = 1)\n",
        "  comp = competitor(G, p = p)\n",
        "  Regret = Regret - np.sum(G*comp)\n",
        "  print(Regret)\n",
        "  return(Regret)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "VqE1DEoCGG0F"
      },
      "outputs": [],
      "source": [
        "# This runs the FTRL with regualrizer psi_2(x) = \\norm{x}_2^2 / 2 (Section 2.2)\n",
        "def FTRL_psi2(d, T, p):\n",
        "  a = np.array([0 for i in range(d)])\n",
        "  Losses = np.zeros([d,T])\n",
        "  Regret = 0\n",
        "  x = np.array([1/(d**((p-1)/p)) for i in range(d)])\n",
        "  e1 = np.array([0 for i in range(d)])\n",
        "  e1[0] = 1\n",
        "  q = p/(p-1)\n",
        "\n",
        "  for t in range(T):\n",
        "    x = np.array([1/(d**((p-1)/p)) for i in range(d)])\n",
        "    if t < T/2:\n",
        "      x = (-1)**(t+1) * e1\n",
        "    Losses[:,t] = x\n",
        "    Regret += sum(a*x)\n",
        "\n",
        "    eta = np.sqrt(d**(1-2/p) / (2*(t+1)))\n",
        "    G = - eta * Losses.sum(axis = 1)\n",
        "    a = l2_projection_onto_lp_ball(G, p, 1)\n",
        "  G = Losses.sum(axis = 1)\n",
        "  comp = competitor(G, p = p)\n",
        "  Regret = Regret - np.sum(G*comp)\n",
        "  print(Regret)\n",
        "  return(Regret)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "fuxcAqS03-GR"
      },
      "source": [
        "# Experiment"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "collapsed": true,
        "id": "-YKYWX32TWOl",
        "outputId": "fac7ae20-86c9-4f0b-db45-235830d647c8"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "1\n",
            "11.78962202628073\n",
            "6.89293627205584\n",
            "6.89293627205584\n",
            "7.109038806236743\n",
            "2\n",
            "11.788070372076744\n",
            "9.083266683018493\n",
            "9.083266683018493\n",
            "9.361844788054999\n",
            "4\n",
            "11.788814368105104\n",
            "11.87760696961292\n",
            "11.87760696961292\n",
            "12.44769862879738\n",
            "6\n",
            "11.790431658847055\n",
            "13.954865812394651\n",
            "13.954865812394651\n",
            "14.768377674027537\n",
            "8\n",
            "11.789674645136348\n",
            "15.685106008981736\n",
            "15.685106008981736\n",
            "16.687093890006455\n",
            "12\n",
            "11.78898206051024\n",
            "17.989163526744345\n",
            "17.989163526744345\n",
            "16.997042658315408\n",
            "20\n",
            "11.789312197238955\n",
            "20.622434513432236\n",
            "20.545643837022865\n",
            "11.789312197238955\n",
            "30\n",
            "11.78870165672958\n",
            "22.478767067983753\n",
            "22.401976391574383\n",
            "11.78870165672958\n",
            "40\n",
            "11.790288986225468\n",
            "23.6576923695454\n",
            "23.580901198290825\n",
            "11.790288986225468\n",
            "50\n",
            "11.788739458231428\n",
            "24.476472533226506\n",
            "24.226770763959266\n",
            "11.788739458231428\n",
            "100\n",
            "11.788830938944633\n",
            "26.263607511787452\n",
            "25.80076124017125\n",
            "11.788830938944633\n",
            "200\n",
            "11.788691459804413\n",
            "27.168371672438198\n",
            "25.931851963576207\n",
            "11.788691459804413\n",
            "300\n",
            "11.790244743136112\n",
            "27.5923466315168\n",
            "25.156993451390456\n",
            "11.790244743136112\n",
            "600\n",
            "11.791066675267965\n",
            "28.1753456261334\n",
            "12.512177499564341\n",
            "11.791066675267965\n"
          ]
        }
      ],
      "source": [
        "p = 10\n",
        "d_vals = np.array([1, 2, 4, 6, 8, 12, 20, 30, 40, 50, 100, 200, 300, 600])\n",
        "T = 40\n",
        "\n",
        "Regrets_psi2 = np.zeros([len(d_vals)])\n",
        "Regrets_psip = np.zeros([len(d_vals)])\n",
        "Regrets_t0opt = np.zeros([len(d_vals)])\n",
        "Regrets_t0_d = np.zeros([len(d_vals)])\n",
        "\n",
        "for i, d in enumerate(d_vals):\n",
        "  print(d)\n",
        "  Regrets_psip[i] = FTRL_psip(d, T, p)\n",
        "  Regrets_psi2[i] = FTRL_psi2(d, T, p)\n",
        "  Regrets_t0opt[i] = FTRL_opt(d, T, p, d * 3**(-2*p/(p-2)))\n",
        "  Regrets_t0_d[i] = FTRL_opt(d, T, p, 2*d)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "Rft6My1fYqWu",
        "outputId": "d0fd111c-ef44-456f-c09b-b0fa22eae19a"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 700x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.figure(figsize=(7,3))\n",
        "\n",
        "plt.plot(d_vals, Regrets_psi2, label = r\"FTRL - $\\phi_2$\")\n",
        "plt.plot(d_vals, Regrets_psip, label = r\"FTRL - $\\phi_p$\")\n",
        "plt.plot(d_vals, Regrets_t0opt, label = r\"FTRL - $t_0 = 3^{-2p/(p-2) d}$\")\n",
        "plt.plot(d_vals, Regrets_t0_d, label = r\"FTRL - $t_0 = 2d$\")\n",
        "\n",
        "plt.xlabel('dimension')\n",
        "plt.ylabel('Regret')\n",
        "\n",
        "plt.xscale('log')\n",
        "plt.legend()\n",
        "plt.tight_layout()\n",
        "plt.savefig('NeurIPS_25_simulation.pdf', format = \"pdf\", bbox_inches = \"tight\")"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "collapsed_sections": [
        "CB3fbntwpcxw",
        "ZQ8Kse-qf2Ff",
        "6LjQO9puRNOS",
        "6kddFQV-RNOa"
      ],
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
