{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "misspecification",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Qz0uJxkAAwC4",
        "outputId": "bc1945e3-2e72-4571-844f-5c5925081671"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0.710165077151136 0.17971590758590583\n"
          ]
        }
      ],
      "source": [
        "%reset -f\n",
        "import numpy as np\n",
        "from matplotlib import pyplot as plt\n",
        "from sklearn.preprocessing import normalize\n",
        "\n",
        "d = 16\n",
        "N = 100\n",
        "eps = 0.02\n",
        "# Delta = 0.1\n",
        "np.random.seed(seed=41)\n",
        "theta_star = np.random.normal(size=(d,))\n",
        "theta_star = theta_star / np.linalg.norm(theta_star)\n",
        "\n",
        "X = normalize(np.random.normal(size=(d, N)), axis=0)\n",
        "\n",
        "r = np.dot(theta_star, X) + 2 * eps * (np.random.binomial(1, 0.5, size=(N,)) - 0.5)\n",
        "r_optimal = max(r)\n",
        "Delta = min([r_optimal - x for x in r if x != r_optimal])\n",
        "print(r_optimal, Delta)"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import time\n",
        "# t = 1000 * time.time() # current time in milliseconds\n",
        "# np.random.seed(int(t) % 2**32)\n",
        "np.random.seed(0)\n",
        "import matplotlib.patheffects as path_effects\n",
        "\n",
        "K = 2000\n",
        "M = 32\n",
        "for Gamma, c in [(0, 'black'), (0.02, 'orange'), (0.08, 'red'), (0.2, 'green')]:\n",
        "  ave = np.zeros((K + 1,))\n",
        "  ave2 = np.zeros((K + 1,))\n",
        "  t0 = time.time()\n",
        "  for i in range(M):\n",
        "    U = np.eye(d)\n",
        "    Uinv = np.eye(d)\n",
        "    b = np.zeros(d)\n",
        "    theta = np.zeros(d)\n",
        "    beta = 3\n",
        "    reg = [0]\n",
        "    for i in range(K):\n",
        "      UCB = np.sqrt(np.einsum('in, ij, jn -> n', X, Uinv, X))\n",
        "      est_r = beta * UCB + np.dot(theta, X)\n",
        "      idx = np.argmax(est_r)\n",
        "      reg.append(reg[-1] + r_optimal - r[idx])\n",
        "      if UCB[idx] > Gamma:\n",
        "        U += np.outer(X[:, idx], X[:, idx])\n",
        "        b += (r[idx] + np.random.normal()) * X[:, idx]\n",
        "        Uinv = np.linalg.inv(U)\n",
        "        theta = np.matmul(Uinv, b)\n",
        "    ave += np.array(reg)\n",
        "    ave2 += np.array(reg) ** 2\n",
        "  ave = ave / M\n",
        "  var = np.sqrt(np.abs(ave2 / M - ave ** 2))\n",
        "  if Gamma != 0:\n",
        "    plt.plot(ave, color=c, label='$\\Gamma = {}$'.format(Gamma))\n",
        "  else:\n",
        "    plt.plot(ave, color=c, label='$\\Gamma = {}$ (OFUL)'.format(Gamma))\n",
        "  # plt.fill_between(np.arange(K + 1), ave - var, ave + var, alpha=0.1, color=c)\n",
        "  print('Gamma = {}, Regret = {}, Variance = {}, Time = {}'.format(Gamma, ave[-1], var[-1], time.time() - t0))\n",
        "plt.legend(loc='lower right')\n",
        "# plt.title('Cumulative Regret')\n",
        "plt.xlabel('# or rounds')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.savefig('syn-nfill.pdf')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 349
        },
        "id": "NLel7jAZNoPV",
        "outputId": "56081d5e-1cf7-408d-9edf-1845699c2a12"
      },
      "execution_count": 2,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Gamma = 0, Regret = 305.1472244014689, Variance = 43.98120676820261, Time = 19.070048570632935\n",
            "Gamma = 0.02, Regret = 332.28358476204073, Variance = 76.17291185546435, Time = 8.428504943847656\n",
            "Gamma = 0.08, Regret = 184.74887362631478, Variance = 61.90793044273028, Time = 5.651626825332642\n",
            "Gamma = 0.2, Regret = 374.63040396933224, Variance = 277.51457910221137, Time = 4.8388752937316895\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import time\n",
        "# t = 1000 * time.time() # current time in milliseconds\n",
        "# np.random.seed(int(t) % 2**32)\n",
        "np.random.seed(0)\n",
        "import matplotlib.patheffects as path_effects\n",
        "\n",
        "K = 2000\n",
        "M = 32\n",
        "for Gamma, c in [(0, 'black'), (0.02, 'orange'), (0.08, 'red'), (0.2, 'green')]:\n",
        "  ave = np.zeros((K + 1,))\n",
        "  ave2 = np.zeros((K + 1,))\n",
        "  t0 = time.time()\n",
        "  for i in range(M):\n",
        "    U = np.eye(d)\n",
        "    Uinv = np.eye(d)\n",
        "    b = np.zeros(d)\n",
        "    theta = np.zeros(d)\n",
        "    beta = 3\n",
        "    reg = [0]\n",
        "    for i in range(K):\n",
        "      UCB = np.sqrt(np.einsum('in, ij, jn -> n', X, Uinv, X))\n",
        "      est_r = beta * UCB + np.dot(theta, X)\n",
        "      idx = np.argmax(est_r)\n",
        "      reg.append(reg[-1] + r_optimal - r[idx])\n",
        "      if UCB[idx] > Gamma:\n",
        "        U += np.outer(X[:, idx], X[:, idx])\n",
        "        b += (r[idx] + np.random.normal()) * X[:, idx]\n",
        "        Uinv = np.linalg.inv(U)\n",
        "        theta = np.matmul(Uinv, b)\n",
        "    ave += np.array(reg)\n",
        "    ave2 += np.array(reg) ** 2\n",
        "  ave = ave / M\n",
        "  var = np.sqrt(np.abs(ave2 / M - ave ** 2))\n",
        "  if Gamma != 0:\n",
        "    plt.plot(ave, color=c, label='$\\Gamma = {}$'.format(Gamma))\n",
        "  else:\n",
        "    plt.plot(ave, color=c, label='$\\Gamma = {}$ (OFUL)'.format(Gamma))\n",
        "  plt.fill_between(np.arange(K + 1), ave - var, ave + var, alpha=0.1, color=c)\n",
        "  print('Gamma = {}, Regret = {}, Variance = {}, Time = {}'.format(Gamma, ave[-1], var[-1], time.time() - t0))\n",
        "plt.legend(loc='lower right')\n",
        "# plt.title('Cumulative Regret')\n",
        "plt.xlabel('# or rounds')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.savefig('syn-fill.pdf')"
      ],
      "metadata": {
        "id": "O9gSunaUXTPn",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 349
        },
        "outputId": "29649d3b-5c9d-4237-86d1-9219266fcaea"
      },
      "execution_count": 3,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Gamma = 0, Regret = 305.1472244014689, Variance = 43.98120676820261, Time = 8.509865283966064\n",
            "Gamma = 0.02, Regret = 332.28358476204073, Variance = 76.17291185546435, Time = 8.38187551498413\n",
            "Gamma = 0.08, Regret = 184.74887362631478, Variance = 61.90793044273028, Time = 5.65099024772644\n",
            "Gamma = 0.2, Regret = 374.63040396933224, Variance = 277.51457910221137, Time = 4.8056464195251465\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    }
  ]
}