{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "uJINq8_ltS_M"
      },
      "source": [
        "## Application 1: Distance Metric Learning"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 958
        },
        "id": "3epV-rfVqCiW",
        "outputId": "cecdd9b0-7eaa-4f11-820a-1462f3f7b576"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "Running seeds for dataset=iris: 100%|██████████| 5/5 [22:49<00:00, 273.80s/it]\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 900x500 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwwAAAHACAYAAAAPyu+dAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAwxlJREFUeJzs3Xd8VfX9+PHXOXev7A0JYQ9REBFcVVCRqnVrtVSLo3Z862jp0g61ra2tttZa6Q87HK1ardbV1kVVigIuhoiyRwiQPe69ufvec35/nAxiAuRAyL0J7+fjwcPcm5NzPsl9J573/Xzen7ei67qOEEIIIYQQQvRCTfcAhBBCCCGEEJlLEgYhhBBCCCHEPknCIIQQQgghhNgnSRiEEEIIIYQQ+yQJgxBCCCGEEGKfJGEQQgghhBBC7JMkDEIIIYQQQoh9koRBCCGEEEIIsU/WdA8g02maxp49e/D5fCiKku7hCCGEEEIIcch0XScYDFJWVoaq7n8OQRKGA9izZw/l5eXpHoYQQgghhBD9rrq6muHDh+/3GEkYDsDn8wHGDzMrK2tAr51IJHjttdc466yzsNlsA3ptMThJzAizJGaEWRIzwiyJmcwUCAQoLy/vvNfdH0kYDqBjGVJWVlZaEga3201WVpb8gok+kZgRZknMCLMkZoRZEjOZrS9L7qXoWQghhBBCCLFPkjAIIYQQQggh9kkSBiGEEEIIIcQ+SQ2DEEIIIYToQdd1kskkqVTqkM6TSCSwWq1Eo9FDPpcwx2azYbFYDvk8kjAIIYQQQohu4vE4NTU1hMPhQz6XruuUlJRQXV0tPa0GmKIoDB8+HK/Xe0jnkYRBCCGEEEJ00jSN7du3Y7FYKCsrw263H9KNvqZptLW14fV6D9ggTPQfXddpaGhg165djB079pBmGiRhEEIIIYQQneLxOJqmUV5ejtvtPuTzaZpGPB7H6XRKwjDACgsL2bFjB4lE4pASBnnVhBBCCCFED3JzP/j11xIwiQQhhBBCCCHEPknCIIQQQgghhNgnSRiEEEIIIYQQ+yQJgxBCCCGEGBIaGhr4+te/TkVFBQ6Hg5KSEubOncuyZcs6j1m9ejWXXXYZxcXFOJ1Oxo4dy/XXX8+mTZsA2LFjB4qiYLFY2L17d7fz19TUYLVaURSFHTt2AFBaWsovf/nLbsfdcsstKIrCkiVLuj0/a9YsrrrqKgDuuOMOpk6d2uN76Lj+mjVrDu2H0Y8kYRBCCCGEEEPCJZdcwurVq3n00UfZtGkTL774IrNmzaKpqQmAf//735xwwgnEYjEef/xx1q9fz2OPPUZ2djY//vGPu51r2LBh/PWvf+323KOPPsqwYcO6PTdr1qweicGbb75JeXl5t+ej0SjvvPMOp59+ev99wwNEtlUVQgghhBD7pes6kcTBdWnWNI1IPIU1njS985LLZunzTj+tra289dZbLFmyhNNOOw2AESNGMGPGDADC4TDXXHMN55xzDs8991zn140cOZKZM2fS2tra7Xzz58/n4Ycf5tZbb+187uGHH2b+/Pn87Gc/63xu9uzZfPvb3yaZTGK1WgkGg6xevZrf/va3PP30053HrVixglgsxuzZs039DDKBJAwZ7OmVu3lyo0pyWA2XTK9I93CEEEIIcYSKJFJMuu3VAb/uJz+di9vet9tVr9eL1+vl+eef54QTTsDhcHT7/KuvvkpjYyPf+973ev36nJycbo/PP/98Fi1axNtvv80pp5zC22+/TUtLC+edd16PhKGtrY3333+fE088kbfeeotx48ZxySWX8J3vfIdoNIrT6eTNN9+ksrKSyspKUz+DTCBLkjKYff0/mR9chGXDC+keihBCCCFERrNarTzyyCM8+uij5OTkcPLJJ/ODH/yAtWvXArB582YAJkyY0Kfz2Ww2rrzySh566CEAHnroIa688kpsNlu348aOHcuwYcM6lx91zHCUlJRQUVHBihUrOp8fjLMLIDMMGW14eD0nWN5meWhUuocihBBCiCOYy2bhk5/OPaiv1TSNYCCIL8t3UEuSzLjkkks499xzeeutt3jnnXd4+eWXufvuu/nzn/+MruumzgVw7bXXctJJJ/GLX/yCp59+mhUrVpBMJnsc11HHcOutt7JkyRK++93vAnDaaaexZMkSTjjhBN59912uv/5602PIBDLDkMmU9pfnIAJcCCGEEKK/KIqC22496H8uu+Wgvu5gOhU7nU7mzJnDj3/8Y5YvX87VV1/N7bffzrhx4wDYsGFDn8919NFHM2HCBL7whS8wceJEJk+e3Otxs2fPZtmyZTQ1NbF69erOGorTTjuNN998k+XLlxOPx7sVPGdlZeH3+3ucq6OWIjs7u8/jPNwkYchgOh2/JFpaxyGEEEIIMVhNmjSJUCjEWWed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I4QQQogj3Q/27PtzyqeW9nzX2DZf0zQCwSBZPl/XTa3yqZvbb350yEMbM2YMiqKwfv16Lrrooh6fX79+Pbm5uRQWFgLGu/LnnXce5513HnfeeSdz587lzjvvZM6cOYwbNw6/309NTQ2lpaV9uv7ZZ5/NV77yFa677jrOO++8zh2ZPm327Nk89dRTfPzxx0QiEaZNmwbAaaedxptvvommabjd7m6b/GRlZVFVVdXjXK2trVgsFjweT5/GeLAkYeijdBQ95/vX8VnrSywLxaW4TPSJFCMKsyRmhFkSM0Pffouera79f/Hex7cfq+s62FLoNjfa3n0Yejl2n+fqg9zcXM4880z+8Ic/cPPNN3cuBwKora3l8ccf56qrruosIP608ePHs2LFCjRN4+KLL+aWW27hV7/6Vbei5w6tra3k5OR0KzpWVZWrrrqKe+65h//85z/dfn57/xxPO+007rzzTh5//HFOPvlkFEVB0zROOeUU/vjHP6JpGieddBJWq7Xz68aNG8eTTz5JJBLB4XB0nmvlypWMHDkSi8UiRc/pkAlFz9b6OgBi0ah0ehamSDGiMEtiRpglMTN0DeZOz3fddRdz585lzpw5/PCHP2TEiBFs2LCB2267jdLSUr7//e+zbNky7rrrLi6//HLGjx+P3W5n2bJlPPzww9x8882d9as///nP+d73vkdTUxNXXHEF5eXl7NmzhyeffBKv18udd97Zo+j4O9/5Dl/96lfJy8sjEAgQiUSA7vUCkydPxuFw8MADD7BgwYLOz02YMIH6+npefPFFvvnNb3b7mvPOO4+f/vSnfPGLX+Smm24iKyuL5cuX87vf/Y477rhjn/UI/VX0rOi9pViiU0fQNDY2DnjR84dP/5zpm37LcvcZHP+tpwb02mJwkmJEYZbEjDBLYmbo6yh6rqysHJSdnquqqrjjjjt49dVXaW5upqSkhAsuuKCzcVtjYyN33nknb775Jjt27EBRFCorK/nSl77EN7/5zW61AP/973/5zW9+w/vvv9/ZuO3cc8/lW9/6FqWlpSxZsoQzzjiDpqamXhunPf/881xyySWdb0B3OP300/nf//7H8uXLuy09OuOMM1iyZAnLli3jhBNO6PY1mzZt4tZbb+W9997D7/czZswY/u///o/rrrtunz/XaDTKjh07KC8v77XouaCgAL/ff8B7XJlh6KP0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LbEe0NzcLIYOHSpWrFghZsyYEQsYeLyw9jzwwAPiggsuSPm4ruuioKBA/OpXv4rd19jYKMxms1i6dKkQQogdO3YIAGL9+vWxbf75z38KSZLEsWPHhBBCvPDCC8LtdsfGUXTfw4cP7+63xHrY1VdfLW677bak+2644QYxZ84cIQSPmTMdL0nqg0KhEDZu3IhZs2bF7pNlGbNmzcKXX37Zi0fGekNTUxMAICsrCwCwceNGhMPhpPExYsQIlJaWxsbHl19+ibFjxyI/Pz+2zezZs+HxePD111/Htkl8jeg2PMb6p/nz5+Pqq69u853yeGHteeeddzBlyhR861vfQl5eHiZOnIjf//73sccPHDiAqqqqpO88MzMT5513XtK4cblcmDJlSmybWbNmQZZlrF27NrbNRRddBJPJFNtm9uzZqKioQENDQ0+/TdaNzj//fHz00UfYvXs3AGDLli1YtWoVrrzySgA8Zs50ht4+ANZWbW0tNE1L+s8bAPLz87Fr165eOirWG3Rdx913343p06djzJgxAICqqiqYTCa4XK6kbfPz81FVVRXbpr3xE32so208Hg8CgQCsVmtPvCXWA5YtW4avvvoK69evb/MYjxfWnv379+PFF1/Evffei//4j//A+vXrceedd8JkMmHevHmx77297zxxTOTl5SU9bjAYkJWVlbTNwIED27xG9DG3290j7491v5/97GfweDwYMWIEFEWBpml4/PHHMWfOHADgMXOG44CBsT5s/vz52L59O1atWtXbh8L6qCNHjuCuu+7CihUrYLFYevtwWD+h6zqmTJmCJ554AgAwceJEbN++HS+99BLmzZvXy0fH+qK//vWv+Mtf/oJXX30Vo0ePxubNm3H33XejqKiIx8xZgJck9UE5OTlQFKVNFZPq6moUFBT00lGx023BggV49913sXLlShQXF8fuLygoQCgUQmNjY9L2ieOjoKCg3fETfayjbZxOJ18t7kc2btyImpoaTJo0CQaDAQaDAZ9++imee+45GAwG5Ofn83hhbRQWFmLUqFFJ940cORKHDx8GEP/eO/p/qKCgADU1NUmPq6qK+vr6tMYW6x/uv/9+/OxnP8O//Mu/YOzYsZg7dy7uuecePPnkkwB4zJzpOGDog0wmEyZPnoyPPvoodp+u6/joo48wbdq0XjwydjoIIbBgwQK8+eab+Pjjj9tM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\n"
          },
          "metadata": {}
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "{'gaps_s_all': array([[1.19858689e-01, 1.15841114e-01, 7.91221437e-02, ...,\n",
              "         6.85273236e-05, 6.85064461e-05, 6.84837160e-05],\n",
              "        [1.23998049e-01, 6.32889101e-02, 4.47471008e-02, ...,\n",
              "         5.77375032e-05, 5.76973617e-05, 5.76560821e-05],\n",
              "        [1.30097762e-01, 1.00436255e-01, 6.73869522e-02, ...,\n",
              "         5.37921548e-05, 5.37585873e-05, 5.37252932e-05],\n",
              "        [1.25398940e-01, 9.05962236e-02, 6.15227041e-02, ...,\n",
              "         9.08521292e-05, 9.07278547e-05, 9.06016572e-05],\n",
              "        [1.28259815e-01, 8.36540217e-02, 5.94333621e-02, ...,\n",
              "         7.03255537e-05, 7.04225080e-05, 7.05147832e-05]]),\n",
              " 'gaps_o_all': array([[1.19858689e-01, 1.14425601e-01, 6.82066447e-02, ...,\n",
              "         3.18833267e-05, 3.19282760e-05, 3.19706917e-05],\n",
              "        [1.23998049e-01, 3.62700513e-02, 2.68109321e-02, ...,\n",
              "         3.10177073e-05, 3.10069316e-05, 3.09959534e-05],\n",
              "        [1.30097762e-01, 7.85960875e-02, 4.94651791e-02, ...,\n",
              "         3.90357397e-05, 3.90330205e-05, 3.90302131e-05],\n",
              "        [1.25398940e-01, 7.15915231e-02, 4.45812448e-02, ...,\n",
              "         3.19437755e-05, 3.19387863e-05, 3.19336462e-05],\n",
              "        [1.28259815e-01, 6.22281492e-02, 4.19825578e-02, ...,\n",
              "         2.32338972e-05, 2.31947202e-05, 2.31546633e-05]]),\n",
              " 'mean_s': array([1.25522651e-01, 9.07633051e-02, 6.24424526e-02, ...,\n",
              "        6.82469329e-05, 6.82225516e-05, 6.81963063e-05]),\n",
              " 'std_s': array([3.54524715e-03, 1.74807019e-02, 1.11864758e-02, ...,\n",
              "        1.29211679e-05, 1.28949212e-05, 1.28682884e-05]),\n",
              " 'mean_o': array([1.25522651e-01, 7.26222824e-02, 4.62093117e-02, ...,\n",
              "        3.14228893e-05, 3.14203469e-05, 3.14170335e-05]),\n",
              " 'std_o': array([3.54524715e-03, 2.53526683e-02, 1.33513783e-02, ...,\n",
              "        5.01323409e-06, 5.02615990e-06, 5.03940471e-06])}"
            ]
          },
          "metadata": {},
          "execution_count": 1
        }
      ],
      "source": [
        "!pip -q install numpy scipy matplotlib tqdm scikit-learn\n",
        "\n",
        "import numpy as np\n",
        "import scipy.linalg as scilin\n",
        "from tqdm import tqdm\n",
        "import matplotlib.pyplot as plt\n",
        "from sklearn.datasets import load_iris, load_digits, load_breast_cancer\n",
        "from sklearn.preprocessing import StandardScaler\n",
        "\n",
        "# ---------------------------\n",
        "# Utilities\n",
        "# ---------------------------\n",
        "def sym(M):\n",
        "    return 0.5 * (M + M.T)\n",
        "\n",
        "# ---------------------------\n",
        "# Nonnegative orthant (simplex) as EJA\n",
        "# ---------------------------\n",
        "class NO:\n",
        "    @staticmethod\n",
        "    def e(m):          return np.ones(m, dtype=float)\n",
        "    @staticmethod\n",
        "    def zeros(m):      return np.zeros(m, dtype=float)\n",
        "    @staticmethod\n",
        "    def tr(x):         return float(np.sum(x))\n",
        "    @staticmethod\n",
        "    def inner(x, y):   return float(np.dot(x, y))\n",
        "    @staticmethod\n",
        "    def eigvals(x):    return np.array(x, dtype=float)\n",
        "\n",
        "    @staticmethod\n",
        "    def exp(x):        return np.exp(x)\n",
        "    @staticmethod\n",
        "    def ln(x):         return np.log(x)\n",
        "\n",
        "# ---------------------------\n",
        "# PSD cone (spectraplex = {Y PSD, tr(Y)=1})\n",
        "# ---------------------------\n",
        "class PSD:\n",
        "    @staticmethod\n",
        "    def e(n):          return np.eye(n, dtype=float)\n",
        "    @staticmethod\n",
        "    def zeros(n):      return np.zeros((n, n), dtype=float)\n",
        "    @staticmethod\n",
        "    def tr(X):         return float(np.real(np.trace(X)))\n",
        "    @staticmethod\n",
        "    def inner(X, Y):   return float(np.real(np.trace(X @ Y)))\n",
        "    @staticmethod\n",
        "    def eigvals(X):    return np.real(np.linalg.eigvalsh(sym(X)))\n",
        "\n",
        "    @staticmethod\n",
        "    def exp(X):        return sym(np.real(scilin.expm(sym(X))))\n",
        "    @staticmethod\n",
        "    def ln(X):         return sym(np.real(scilin.logm(sym(X))))\n",
        "\n",
        "# ---------------------------\n",
        "# Second-order cone Jordan algebra\n",
        "# ---------------------------\n",
        "class SOC:\n",
        "    @staticmethod\n",
        "    def e(d):\n",
        "        v = np.zeros(d, dtype=float)\n",
        "        return np.concatenate([v, np.array([1.0])])\n",
        "\n",
        "    @staticmethod\n",
        "    def zeros(d):\n",
        "        v = np.zeros(d, dtype=float)\n",
        "        return np.concatenate([v, np.array([0.0])])\n",
        "\n",
        "    @staticmethod\n",
        "    def tr(x):\n",
        "        return float(2.0 * x[-1])\n",
        "\n",
        "    @staticmethod\n",
        "    def inner(x, y):\n",
        "        return float(2.0 * np.dot(x, y))\n",
        "\n",
        "    @staticmethod\n",
        "    def eigvals(x):\n",
        "        v = x[:-1]\n",
        "        t = x[-1]\n",
        "        nv = np.linalg.norm(v)\n",
        "        return np.array([t - nv, t + nv], dtype=float)\n",
        "\n",
        "    @staticmethod\n",
        "    def exp(x):\n",
        "        v = x[:-1]\n",
        "        t = x[-1]\n",
        "        nv = np.linalg.norm(v)\n",
        "        d = len(v)\n",
        "        if nv > 0:\n",
        "            u = v / nv\n",
        "            lam1, lam2 = t - nv, t + nv\n",
        "            e1, e2 = np.exp(lam1), np.exp(lam2)\n",
        "            v1 = 0.5 * np.concatenate([-u, np.array([1.0])])\n",
        "            v2 = 0.5 * np.concatenate([ u, np.array([1.0])])\n",
        "            return e1 * v1 + e2 * v2\n",
        "        else:\n",
        "            return np.exp(t) * SOC.e(d)\n",
        "\n",
        "    @staticmethod\n",
        "    def ln(x):\n",
        "        v = x[:-1]\n",
        "        t = x[-1]\n",
        "        nv = np.linalg.norm(v)\n",
        "        d = len(v)\n",
        "        if nv > 0:\n",
        "            u = v / nv\n",
        "            lam1, lam2 = t - nv, t + nv\n",
        "            if lam1 <= 0 or lam2 <= 0:\n",
        "                raise ValueError(\"SOC.ln requires interior point (positive Jordan eigenvalues).\")\n",
        "            l1, l2 = np.log(lam1), np.log(lam2)\n",
        "            v1 = 0.5 * np.concatenate([-u, np.array([1.0])])\n",
        "            v2 = 0.5 * np.concatenate([ u, np.array([1.0])])\n",
        "            return l1 * v1 + l2 * v2\n",
        "        else:\n",
        "            if t <= 0:\n",
        "                raise ValueError(\"SOC.ln requires interior point.\")\n",
        "            return np.log(t) * SOC.e(d)\n",
        "\n",
        "# ---------------------------\n",
        "# Trace-normalization to generalized simplex\n",
        "# ---------------------------\n",
        "def normalize_trace(exp_w, tr_fn, eps=1e-12):\n",
        "    trv = tr_fn(exp_w)\n",
        "    if trv <= eps:\n",
        "        raise ValueError(\"Trace became non-positive; check stepsize / exp stability.\")\n",
        "    return exp_w / trv\n",
        "\n",
        "# ---------------------------\n",
        "# SCMWU / OSCMWU for a single symmetric cone variable\n",
        "# ---------------------------\n",
        "def sc_update_SCMWU(cone, w, eta):\n",
        "    x_unnorm = cone.exp(w)\n",
        "    x = normalize_trace(x_unnorm, cone.tr)\n",
        "    return x\n",
        "\n",
        "# ---------------------------\n",
        "# Simplex MWU\n",
        "# ---------------------------\n",
        "def simplex_mwu_init(m):\n",
        "    return np.ones(m, dtype=float) / m\n",
        "\n",
        "\n",
        "def simplex_mwu_step(p, eta, grad, prev_grad=None, optimistic=False):\n",
        "    \"\"\"\n",
        "    Minimizer MWU update. If optimistic=True and prev_grad is provided,\n",
        "    uses the typical optimistic choice corresponding to \\tilde m^{t+1} = m^t:\n",
        "        g_eff = 2*grad - prev_grad\n",
        "    Otherwise:\n",
        "        g_eff = grad\n",
        "    \"\"\"\n",
        "    if optimistic and (prev_grad is not None):\n",
        "        g_eff = 2.0 * grad - prev_grad\n",
        "    else:\n",
        "        g_eff = grad\n",
        "    w = p * np.exp(-eta * g_eff)\n",
        "    return w / np.sum(w)\n",
        "\n",
        "def simplex_oscmwu_step_from_sum(sum_grad, eta, grad, optimistic=False):\n",
        "    \"\"\"\n",
        "    SCMWU/OSCMWU for simplex:\n",
        "      SCMWU:  x ∝ exp(-η * sum_{k<=t} g^k)\n",
        "      OSCMWU (tilde = g^t): x ∝ exp(-η * (sum_{k<=t} g^k + g^t))\n",
        "                          = exp(-η * (sum_{k<=t-1} g^k + 2 g^t))\n",
        "    \"\"\"\n",
        "    if optimistic:\n",
        "        expo = -eta * (sum_grad + grad)\n",
        "    else:\n",
        "        expo = -eta * sum_grad\n",
        "\n",
        "    # stabilize\n",
        "    expo = expo - np.max(expo)\n",
        "    x = np.exp(expo)\n",
        "    x /= (x.sum() + 1e-18)\n",
        "    return x\n",
        "\n",
        "\n",
        "\n",
        "# ---------------------------\n",
        "# Metric learning instance\n",
        "# ---------------------------\n",
        "def make_metric_learning_instance(dataset=\"iris\", max_similar=2000, max_dissimilar=2000, seed=0, reg=1e-6):\n",
        "    rng = np.random.default_rng(seed)\n",
        "\n",
        "    if dataset == \"iris\":\n",
        "        data = load_iris()\n",
        "    elif dataset == \"digits\":\n",
        "        data = load_digits()\n",
        "    elif dataset == \"breast_cancer\":\n",
        "        data = load_breast_cancer()\n",
        "    else:\n",
        "        raise ValueError(\"dataset must be iris/digits/breast_cancer\")\n",
        "\n",
        "    X = StandardScaler().fit_transform(data.data)\n",
        "    y = data.target\n",
        "    n, d = X.shape\n",
        "\n",
        "    pairs = [(i, j) for i in range(n) for j in range(i + 1, n)]\n",
        "    rng.shuffle(pairs)\n",
        "\n",
        "    S, D = [], []\n",
        "    for (i, j) in pairs:\n",
        "        if y[i] == y[j]:\n",
        "            if len(S) < max_similar:\n",
        "                S.append((i, j))\n",
        "        else:\n",
        "            if len(D) < max_dissimilar:\n",
        "                D.append((i, j))\n",
        "        if len(S) >= max_similar and len(D) >= max_dissimilar:\n",
        "            break\n",
        "\n",
        "    def X_ij(i, j):\n",
        "        v = (X[i] - X[j]).reshape(-1, 1)\n",
        "        return v @ v.T\n",
        "\n",
        "    XS = np.zeros((d, d), dtype=float)\n",
        "    for (i, j) in S:\n",
        "        XS += X_ij(i, j)\n",
        "\n",
        "    XS = sym(XS) + reg * np.eye(d)\n",
        "\n",
        "    evals, evecs = np.linalg.eigh(XS)\n",
        "    inv_sqrt = evecs @ np.diag(1.0 / np.sqrt(np.maximum(evals, 1e-12))) @ evecs.T\n",
        "\n",
        "    A_list = []\n",
        "    for (i, j) in D:\n",
        "        Xt = X_ij(i, j)\n",
        "        A = sym(inv_sqrt @ Xt @ inv_sqrt)\n",
        "        A_list.append(A)\n",
        "\n",
        "    return A_list, d\n",
        "\n",
        "# ---------------------------\n",
        "# Game solver with configurable initialization + optional t=0 gap logging\n",
        "# ---------------------------\n",
        "def solve_simplex_spectraplex(\n",
        "    A_list,\n",
        "    T=2000,\n",
        "    eta_x=0.5,\n",
        "    eta_Y=0.5,\n",
        "    optimistic=False,\n",
        "    init_mode=\"uniform\",        # \"uniform\" | \"onehot_maxlam\" | \"random\"\n",
        "    init_seed=0,                # used only if init_mode=\"random\"\n",
        "    log_gap_at_t0=True\n",
        "):\n",
        "    \"\"\"\n",
        "    Solves: min_x max_Y <Y, sum_i x_i A_i>\n",
        "    using MWU for x (simplex) and SCMWU/OSCMWU for Y (spectraplex).\n",
        "    Logs duality gap at ergodic averages; optionally includes t=0 gap at initial point.\n",
        "\n",
        "    init_mode:\n",
        "      - \"uniform\": x uniform, Y = I/d\n",
        "      - \"onehot_maxlam\": x is one-hot on argmax_i lambda_max(A_i), Y = I/d\n",
        "      - \"random\": x ~ Dirichlet(1), Y ~ random PSD trace-1 (seeded by init_seed)\n",
        "    \"\"\"\n",
        "    m = len(A_list)\n",
        "    d = A_list[0].shape[0]\n",
        "\n",
        "\n",
        "\n",
        "    # ---- initialization ----\n",
        "    if init_mode == \"uniform\":\n",
        "        x = simplex_mwu_init(m)\n",
        "        Y = PSD.e(d) / PSD.tr(PSD.e(d))\n",
        "\n",
        "    elif init_mode == \"onehot_maxlam\":\n",
        "        scores = [float(np.max(PSD.eigvals(A_list[i]))) for i in range(m)]\n",
        "        k = int(np.argmax(scores))\n",
        "        x = np.zeros(m, dtype=float)\n",
        "        x[k] = 1.0\n",
        "        Y = PSD.e(d) / PSD.tr(PSD.e(d))\n",
        "\n",
        "    elif init_mode == \"random\":\n",
        "        rng = np.random.default_rng(init_seed)\n",
        "        x = rng.dirichlet(np.ones(m, dtype=float))\n",
        "        G = rng.standard_normal((d, d))\n",
        "        Y = sym(G @ G.T)\n",
        "        Y = Y / PSD.tr(Y)\n",
        "\n",
        "    else:\n",
        "        raise ValueError(\"init_mode must be 'uniform', 'onehot_maxlam', or 'random'.\")\n",
        "\n",
        "    x_avg = np.zeros_like(x)\n",
        "    Y_avg = np.zeros_like(Y)\n",
        "\n",
        "    def gap_at(x_cur, Y_cur):\n",
        "        Ax = PSD.zeros(d)\n",
        "        for i in range(m):\n",
        "            Ax += x_cur[i] * A_list[i]\n",
        "        lam_max = float(np.max(PSD.eigvals(Ax)))\n",
        "        min_over_x = float(np.min([PSD.inner(Y_cur, A_list[i]) for i in range(m)]))\n",
        "        return lam_max - min_over_x\n",
        "\n",
        "    duality_gaps = []\n",
        "    if log_gap_at_t0:\n",
        "        duality_gaps.append(gap_at(x, Y))  # t=0 gap\n",
        "\n",
        "    sum_gradY = PSD.zeros(d)\n",
        "    sum_gradx = np.zeros(m)\n",
        "    last_gradx = None\n",
        "    last_gradY = None\n",
        "\n",
        "    for t in range(1, T + 1):\n",
        "        # gradients at (x, Y)\n",
        "        gradx = np.array([PSD.inner(Y, A_list[i]) for i in range(m)], dtype=float)\n",
        "\n",
        "        gradY = PSD.zeros(d)\n",
        "        for i in range(m):\n",
        "            gradY += x[i] * A_list[i]\n",
        "        gradY = sym(gradY)\n",
        "\n",
        "        sum_gradx += gradx\n",
        "        x = simplex_oscmwu_step_from_sum(sum_gradx, eta_x, gradx, optimistic=optimistic)\n",
        "\n",
        "        # Y update (maximizer): minimize -f, so loss = -gradY\n",
        "        if optimistic and last_gradY is not None:\n",
        "            sum_gradY += (-gradY)\n",
        "            wY = -eta_Y * (sum_gradY + (-gradY))\n",
        "        else:\n",
        "            sum_gradY += (-gradY)\n",
        "            wY = -eta_Y * sum_gradY\n",
        "\n",
        "        Y = sc_update_SCMWU(PSD, wY, eta_Y)\n",
        "\n",
        "        last_gradx = gradx\n",
        "        last_gradY = gradY\n",
        "\n",
        "        # ergodic averages\n",
        "        x_avg = ((t - 1) * x_avg + x) / t\n",
        "        Y_avg = ((t - 1) * Y_avg + Y) / t\n",
        "\n",
        "        duality_gaps.append(gap_at(x_avg, Y_avg))\n",
        "\n",
        "    return np.array(duality_gaps)\n",
        "\n",
        "# ---------------------------\n",
        "# Application 1 with multiple seeds: mean + std shading\n",
        "# (Seeds govern instance construction; optional separate init seeds for random init mode.)\n",
        "# ---------------------------\n",
        "def run_application1_multi_seeds(\n",
        "    dataset=\"iris\",\n",
        "    seeds=(0, 1, 2, 3, 4),\n",
        "    T=10000,\n",
        "    eta_x=0.5,\n",
        "    eta_Y=0.5,\n",
        "    max_similar=500,\n",
        "    max_dissimilar=500,\n",
        "    reg=1e-6,\n",
        "    init_mode=\"onehot_maxlam\",\n",
        "    log_gap_at_t0=True,\n",
        "):\n",
        "    gaps_s = []\n",
        "    gaps_o = []\n",
        "\n",
        "    for seed in tqdm(list(seeds), desc=f\"Running seeds for dataset={dataset}\"):\n",
        "        A_list, d = make_metric_learning_instance(\n",
        "            dataset=dataset,\n",
        "            max_similar=max_similar,\n",
        "            max_dissimilar=max_dissimilar,\n",
        "            seed=int(seed),\n",
        "            reg=reg,\n",
        "        )\n",
        "\n",
        "        # Optionally tie init_seed to the same seed for reproducibility in random init\n",
        "        init_seed = int(seed)\n",
        "\n",
        "        gap_s = solve_simplex_spectraplex(\n",
        "            A_list, T=T, eta_x=eta_x, eta_Y=eta_Y,\n",
        "            optimistic=False,\n",
        "            init_mode=init_mode,\n",
        "            init_seed=init_seed,\n",
        "            log_gap_at_t0=log_gap_at_t0\n",
        "        )\n",
        "        gap_o = solve_simplex_spectraplex(\n",
        "            A_list, T=T, eta_x=eta_x, eta_Y=eta_Y,\n",
        "            optimistic=True,\n",
        "            init_mode=init_mode,\n",
        "            init_seed=init_seed,\n",
        "            log_gap_at_t0=log_gap_at_t0\n",
        "        )\n",
        "\n",
        "        gaps_s.append(gap_s)\n",
        "        gaps_o.append(gap_o)\n",
        "\n",
        "    gaps_s = np.stack(gaps_s, axis=0)  # [num_seeds, T+1 if log_gap_at_t0 else T]\n",
        "    gaps_o = np.stack(gaps_o, axis=0)\n",
        "\n",
        "    mean_s = np.mean(gaps_s, axis=0)\n",
        "    std_s  = np.std(gaps_s, axis=0, ddof=0)\n",
        "\n",
        "    mean_o = np.mean(gaps_o, axis=0)\n",
        "    std_o  = np.std(gaps_o, axis=0, ddof=0)\n",
        "\n",
        "    # x-axis\n",
        "    if log_gap_at_t0:\n",
        "        it = np.arange(0, T + 1)  # includes t=0\n",
        "        xlabel = \"Number of iterations\"\n",
        "    else:\n",
        "        it = np.arange(1, T + 1)\n",
        "        xlabel = \"Number of iterations\"\n",
        "\n",
        "    plt.figure(figsize=(9, 5))\n",
        "\n",
        "    plt.plot(it, mean_s, label=f\"SCMWU\")\n",
        "    plt.plot(it, mean_o, linestyle=\"--\", label=f\"OSCMWU\")\n",
        "\n",
        "    # std shading; clip away from 0 for log scale\n",
        "    eps = 1e-16\n",
        "    lower_s = np.maximum(mean_s - std_s, eps)\n",
        "    upper_s = np.maximum(mean_s + std_s, eps)\n",
        "    lower_o = np.maximum(mean_o - std_o, eps)\n",
        "    upper_o = np.maximum(mean_o + std_o, eps)\n",
        "\n",
        "    plt.fill_between(it, lower_s, upper_s, alpha=0.2)\n",
        "    plt.fill_between(it, lower_o, upper_o, alpha=0.2)\n",
        "\n",
        "    plt.yscale(\"log\")\n",
        "    plt.xlabel(xlabel)\n",
        "    plt.ylabel(\"Duality gap\")\n",
        "    plt.grid(True, which=\"both\")\n",
        "    plt.legend()\n",
        "    plt.savefig(\"plot-appli1-metric-learning.pdf\", dpi=300, bbox_inches=\"tight\")\n",
        "    plt.show()\n",
        "\n",
        "    return {\n",
        "        \"gaps_s_all\": gaps_s,\n",
        "        \"gaps_o_all\": gaps_o,\n",
        "        \"mean_s\": mean_s,\n",
        "        \"std_s\": std_s,\n",
        "        \"mean_o\": mean_o,\n",
        "        \"std_o\": std_o,\n",
        "    }\n",
        "\n",
        "# ---------------------------\n",
        "# Example run (iris-focused, faster pair caps)\n",
        "# ---------------------------\n",
        "run_application1_multi_seeds(\n",
        "    dataset=\"iris\",\n",
        "    seeds=(0, 1, 2, 3, 4),\n",
        "    T=9000,\n",
        "    eta_x=20,\n",
        "    eta_Y=20,\n",
        "    max_similar=400,\n",
        "    max_dissimilar=400,\n",
        "    init_mode=\"random\",  # try \"uniform\" or \"random\" as well\n",
        "    log_gap_at_t0=True\n",
        ")\n",
        "\n",
        "\n",
        "#Setting plot-appli1-metric-learning_saved.pdf\n",
        "# # ---------------------------\n",
        "# # Example run (iris-focused, faster pair caps)\n",
        "# # ---------------------------\n",
        "# run_application1_multi_seeds(\n",
        "#     dataset=\"iris\",\n",
        "#     seeds=(0, 1, 2, 3, 4),\n",
        "#     T=9000,\n",
        "#     eta_x=12,\n",
        "#     eta_Y=12,\n",
        "#     max_similar=400,\n",
        "#     max_dissimilar=400,\n",
        "#     init_mode=\"random\",  # try \"uniform\" or \"random\" as well\n",
        "#     log_gap_at_t0=True\n",
        "# )"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}