{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "Experiment0.ipynb",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "rWaOYHwnPJxF"
      },
      "source": [
        "This generates the `SyntheticData1` model described in the paper and runs the different sampling schemes on it to examine the different scheme's convergence properties to the equalizing distribution.  "
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "GJqwQsjvHRjb"
      },
      "source": [
        "import numpy as np \n",
        "from time import time\n",
        "import matplotlib.pyplot as plt \n",
        "from sklearn.linear_model import LogisticRegression as LogReg\n",
        "import matplotlib.pyplot as plt \n",
        "plt.style.use('seaborn-whitegrid')"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "U0U_He2sGgUd"
      },
      "source": [
        "def Oracle(att, Mu, Sig,  n_samples=2, y_prob=0.5):\n",
        "  if Mu is None or Sig is None:\n",
        "    raise Exception('Please initialize both  Mu and Sig tuples')\n",
        "  # obtain the mean vector and covariance matrix \n",
        "  _Mu, _Sig = Mu[att], Sig[att]\n",
        "  # draw n_samples independent samples from the distribution $P_z$\n",
        "  features, labels = [], []\n",
        "  for i in range(n_samples):\n",
        "    # the labels are 1 with probability y_prob\n",
        "    y = 0 if np.random.random()>y_prob else 1\n",
        "    # find the mean vector and covariance matrix for given y\n",
        "    mu, sig = _Mu[y], _Sig[y]\n",
        "    # draw a multi-variate gaussian \n",
        "    x = np.random.multivariate_normal(mean=mu, cov=sig)\n",
        "    # append the feature and label values \n",
        "    features.append(x)\n",
        "    labels.append(y)\n",
        "  #return the list of feature vectors and the list of label values\n",
        "  return features, labels"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "pOOMcjhXH1Ao"
      },
      "source": [
        "## Toy Model 1 \n",
        "\n",
        "## Change this value to evaluate one of the two different sets of parameters considered in the paper\n",
        "ToyModel='1'\n",
        "\n",
        "if ToyModel=='1':\n",
        "  Mu = (\n",
        "      (np.array([-2,2]), np.array([2,-2])), \n",
        "      (np.array([-1,-1]), np.array([1,1]))\n",
        "  )\n",
        "  \n",
        "  Sig = (\n",
        "      (np.eye(2), np.eye(2)), \n",
        "      (np.eye(2), np.eye(2))\n",
        "  )\n",
        "else:\n",
        "  ## Toy Model 2 \n",
        "  Mu = (\n",
        "      (np.array([-1.5,1.5]), np.array([1.5,-1.5])), \n",
        "      (np.array([-2,-2]), np.array([2,2]))\n",
        "  )\n",
        "  \n",
        "  Sig = (\n",
        "      (np.eye(2), np.eye(2)), \n",
        "      (np.eye(2), np.eye(2))\n",
        "  )\n",
        "  "
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "fsZhtMVTGqoU"
      },
      "source": [
        "\n",
        "def helper1(features, labels, atts,  att=0, return_idx=False):\n",
        "  Idx = [i for i,z in enumerate(atts) if z==att]\n",
        "  if return_idx:\n",
        "    return Idx\n",
        "  if isinstance(features, list):\n",
        "    Xa = np.array(features)[Idx]\n",
        "    Ya = np.array(labels)[Idx]\n",
        "  else: #np array \n",
        "    Xa = features[Idx]\n",
        "    Ya = features[Idx]\n",
        "  return Xa, Ya\n",
        "\n",
        "def bootstrap_acc(Y, Yp, nT=100, q=0.9):\n",
        "  n = len(Y)\n",
        "  Acc = np.zeros((nT,))\n",
        "  for i in range(nT):\n",
        "    acc=0\n",
        "    # get a random sample of size n\n",
        "    for _ in range(n):\n",
        "      j = np.random.randint(0, n)\n",
        "      acc += Y[j]==Yp[j]\n",
        "    Acc[i]=acc/n\n",
        "  return np.quantile(Acc, 1-q)\n",
        "\n",
        "def Experiment0(model, features1, labels1, features2, labels2, \n",
        "                attributes, n0, Mu, Sig, TT=500, rule='UCB', param=None, \n",
        "                forced='True', verbose=True):\n",
        "  '''\n",
        "  rule  :string   possible options are\n",
        "                  ucb0 -- standard UCB\n",
        "                  ucb1 -- bootstrap UCB\n",
        "                  emp  -- empirical, i.e., greedy \n",
        "                  eps   -- epsilon greedy (with epsilon=param)\n",
        "  '''\n",
        "  # sanity check                \n",
        "  assert 2*n0==len(attributes)\n",
        "  # Initialize the Pi_a Vector \n",
        "  Pi_a = np.zeros((TT,))\n",
        "  Pi_a[:n0] = 0.5 # set the first $n0$ elements to 0.5 (technically not correct!!)\n",
        "\n",
        "  # start the main loop\n",
        "  for t in range(2*n0, TT):\n",
        "    # fit the model to the current data\n",
        "    model.fit(features1, labels1)\n",
        "    # Obtain the validation set for attributes\n",
        "    Xa, Ya = helper1(features2, labels2, atts=attributes, att=0)\n",
        "    Xb, Yb = helper1(features2, labels2, atts=attributes, att=1)\n",
        "    # Predict labels on the two validation sets using model\n",
        "    Yap, Ybp = model.predict(Xa), model.predict(Xb)\n",
        "    # Compute the accuracy \n",
        "    acc_a = np.array([1 if ypi==yi else 0 for ypi, yi in zip(Yap, Ya)]).mean()\n",
        "    acc_b = np.array([1 if ypi==yi else 0 for ypi, yi in zip(Ybp, Yb)]).mean()\n",
        "    num_a = len(helper1(features1, labels1, attributes, att=0, return_idx=True))\n",
        "    num_b = len(helper1(features1, labels1, attributes, att=1, return_idx=True))\n",
        "\n",
        "    # Point Selection Rule\n",
        "    if rule=='ucb0':# Optimistic Rule\n",
        "      if param is None:\n",
        "        param=0.1\n",
        "      U_a, U_b = acc_a - param/np.sqrt(num_a), acc_b - param/np.sqrt(num_b)\n",
        "    elif rule=='ucb1': # Optimistic Rule with Bootstrap ### TOO SLOW!!! avoid.\n",
        "      if param is None:\n",
        "        param = 0.95\n",
        "      U_a, U_b = bootstrap_acc(Ya, Yap), bootstrap_acc(Yb, Ybp, q=param)\n",
        "    elif rule=='emp':# Empirical Rule\n",
        "      U_a, U_b = acc_a, acc_b\n",
        "    elif rule=='eps':\n",
        "      if param is None:\n",
        "        param=0.1 # epsilon value for epsilon-greedy sampling\n",
        "      if np.random.random()<param: # randomly choose one of two attributes\n",
        "        if np.random.random()>0.5:\n",
        "          U_a, U_b = 1, 0\n",
        "        else:\n",
        "          U_a, U_b = 0, 1\n",
        "      else: # empirical sampling otherwise\n",
        "        U_a, U_b = acc_a, acc_b\n",
        "\n",
        "  \n",
        "    # choose the attribute with lower value of the index function U \n",
        "    if num_a < np.sqrt(t) and forced:\n",
        "      at=0\n",
        "    elif num_b<np.sqrt(t) and forced:\n",
        "      at=1\n",
        "    else:\n",
        "      at = 0 if U_a<U_b else 1 \n",
        "\n",
        "    # Store the updated Pi_a value \n",
        "    Pi_a[t] = (num_a + 1)/(t+1) if at==0 else num_a/(t+1)\n",
        "\n",
        "    # Print the values \n",
        "    if t%100==99 and verbose:\n",
        "      print('U_a = {:.2f}, \\t U_b = {:.2f}, \\t pi_a = {}, \\t at = {}\\t t = {}'.format(U_a, U_b, num_a/t, at, t))\n",
        "      print('\\n')\n",
        "    # draw a sample from the chosen attribute \n",
        "    xt, yt = Oracle(att=at, Mu=Mu, Sig=Sig, n_samples=2)\n",
        "    features1.append(xt[0])\n",
        "    features2.append(xt[1])\n",
        "    labels1.append(yt[0])\n",
        "    labels2.append(yt[1])\n",
        "    attributes.append(at)\n",
        "\n",
        "  return Pi_a\n",
        "  \n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "background_save": true,
          "base_uri": "https://localhost:8080/"
        },
        "id": "Ao7duETiQ8yS",
        "outputId": "33908175-7ce2-4b71-ff95-67ccdd246b0b"
      },
      "source": [
        "# Run the experiment \n",
        "def runExperiment0(\n",
        "    Mu,\n",
        "    Sig,\n",
        "    n0=2,\n",
        "    rule='ucb0',\n",
        "    forced='True',\n",
        "    param=0.2,\n",
        "    n_trials=10,\n",
        "    TT=500,\n",
        "    verbose=False\n",
        "):\n",
        "\n",
        "  # Initialize the vectors.\n",
        "  PiM1 = np.zeros((TT,)) # first empirical moment\n",
        "  PiM2 = np.zeros((TT,)) # second empirical moment\n",
        "  \n",
        "  start_time = time()\n",
        "  for i in range(n_trials):\n",
        "    print('Starting trial {}/{} with rule = {}, forced = {}'.format(\n",
        "       i+1, n_trials, rule, forced \n",
        "    )\n",
        "    )\n",
        "    # Initialize the model\n",
        "    model = LogReg()\n",
        "    # Get the initial training datasets (2*n0)\n",
        "    while True:\n",
        "      X_temp0, Y_temp0 = Oracle(att=0, Mu=Mu, Sig=Sig, n_samples=n0)\n",
        "      X_temp1, Y_temp1 = Oracle(att=1, Mu=Mu, Sig=Sig, n_samples=n0)\n",
        "      features1, labels1 = X_temp0+X_temp1, Y_temp0+Y_temp1\n",
        "      if len(set(labels1))>1: # ensures at least one element of each label\n",
        "        break\n",
        "    # Get the initial validation dataset (of size 2*n0)\n",
        "    while True:\n",
        "      X_temp0, Y_temp0 = Oracle(att=0, Mu=Mu, Sig=Sig, n_samples=n0)\n",
        "      X_temp1, Y_temp1 = Oracle(att=1, Mu=Mu, Sig=Sig, n_samples=n0)\n",
        "      features2, labels2 = X_temp0+X_temp1, Y_temp0+Y_temp1\n",
        "      if len(set(labels2))>1: # ensures at least one element of each label\n",
        "        break     \n",
        "    # Set the attributes selected so far\n",
        "    attributes = [0]*n0+[1]*n0\n",
        "    # Run the experiment to get one pi vector\n",
        "    pi_temp = Experiment0(model=model,\n",
        "        features1=features1, labels1=labels1, features2=features2, labels2=labels2,\n",
        "        attributes=attributes, n0=n0, Mu=Mu, Sig=Sig, TT=TT,\n",
        "        rule=rule, param=param, forced=forced, verbose=verbose\n",
        "    )\n",
        "    PiM1 = (i/(i+1))*PiM1 + (1/(i+1))*pi_temp\n",
        "    PiM2 = (i/(i+1))*PiM2 + (1/(i+1))*pi_temp*pi_temp\n",
        "  end_time=time()\n",
        "  print('Completed {} trials in {:.2f} seconds \\n \\n'.format(n_trials, -start_time+end_time)) \n",
        "  # get the standard deviation of Pi over n_trials trials\n",
        "  PiStd = np.sqrt( PiM2 - PiM1*PiM1)\n",
        "  # Return the mean and standard deviation \n",
        "  return PiM1, PiStd\n",
        "  \n",
        "\n",
        "# UCB0 rule\n",
        "TT = 5000\n",
        "PiMU0, PiStdU0 = runExperiment0(Mu=Mu, Sig=Sig, rule='ucb0', TT=TT, param= 2)\n",
        "# PiMU1, PiStdU1 = runExperiment0(Mu=Mu, Sig=Sig, rule='ucb0', TT=TT, param= 0.2)\n",
        "# Emp Rule\n",
        "PiMEmp, PiStdEmp = runExperiment0(Mu=Mu, Sig=Sig, rule='emp', forced=False, TT=TT)\n",
        "# Eps Rule with epsilon=0.1\n",
        "PiMEps, PiStdEps = runExperiment0(Mu=Mu, Sig=Sig, rule='eps', forced=False, TT=TT, param=.5)\n",
        "# Eps Rule with epsilon=0.2\n",
        "# PiMEps2, PiStdEps2 = runExperiment0(Mu=Mu, Sig=Sig, rule='eps', forced=False, TT=TT, param=.2)\n",
        "\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "text": [
            "Starting trial 1/10 with rule = ucb0, forced = True\n",
            "Starting trial 2/10 with rule = ucb0, forced = True\n",
            "Starting trial 3/10 with rule = ucb0, forced = True\n",
            "Starting trial 4/10 with rule = ucb0, forced = True\n",
            "Starting trial 5/10 with rule = ucb0, forced = True\n",
            "Starting trial 6/10 with rule = ucb0, forced = True\n",
            "Starting trial 7/10 with rule = ucb0, forced = True\n",
            "Starting trial 8/10 with rule = ucb0, forced = True\n",
            "Starting trial 9/10 with rule = ucb0, forced = True\n",
            "Starting trial 10/10 with rule = ucb0, forced = True\n",
            "Completed 10 trials in 615.34 seconds \n",
            " \n",
            "\n",
            "Starting trial 1/10 with rule = emp, forced = False\n"
          ],
          "name": "stdout"
        },
        {
          "output_type": "stream",
          "text": [
            "/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:53: RuntimeWarning: invalid value encountered in sqrt\n"
          ],
          "name": "stderr"
        },
        {
          "output_type": "stream",
          "text": [
            "Starting trial 2/10 with rule = emp, forced = False\n",
            "Starting trial 3/10 with rule = emp, forced = False\n",
            "Starting trial 4/10 with rule = emp, forced = False\n",
            "Starting trial 5/10 with rule = emp, forced = False\n",
            "Starting trial 6/10 with rule = emp, forced = False\n",
            "Starting trial 7/10 with rule = emp, forced = False\n",
            "Starting trial 8/10 with rule = emp, forced = False\n",
            "Starting trial 9/10 with rule = emp, forced = False\n",
            "Starting trial 10/10 with rule = emp, forced = False\n",
            "Completed 10 trials in 611.65 seconds \n",
            " \n",
            "\n",
            "Starting trial 1/10 with rule = eps, forced = False\n",
            "Starting trial 2/10 with rule = eps, forced = False\n",
            "Starting trial 3/10 with rule = eps, forced = False\n",
            "Starting trial 4/10 with rule = eps, forced = False\n",
            "Starting trial 5/10 with rule = eps, forced = False\n",
            "Starting trial 6/10 with rule = eps, forced = False\n",
            "Starting trial 7/10 with rule = eps, forced = False\n",
            "Starting trial 8/10 with rule = eps, forced = False\n",
            "Starting trial 9/10 with rule = eps, forced = False\n",
            "Starting trial 10/10 with rule = eps, forced = False\n",
            "Completed 10 trials in 620.72 seconds \n",
            " \n",
            "\n"
          ],
          "name": "stdout"
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "background_save": true
        },
        "id": "R_WVW6uwZV_O",
        "outputId": "7f113b70-e1bf-4e55-e33c-e37acc76768d"
      },
      "source": [
        "from google.colab import files\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "NN = np.arange(0, len(PiMU0))\n",
        "\n",
        "# Approximate values found numerically\n",
        "optimum = 0.22 if ToyModel=='1' else 0.639\n",
        "optimum = optimum*np.ones(NN.shape)\n",
        "\n",
        "\n",
        "\n",
        "plt.plot(NN, PiMU0, label='$\\mathcal{A}_{opt} $', color='red')\n",
        "plt.fill_between(NN, PiMU0-PiStdU0, PiMU0+PiStdU0, alpha=0.1, color='red')\n",
        "# plt.plot(NN, PiMU1, label='$\\mathcal{A}_{opt} (0.1)$')\n",
        "# plt.fill_between(NN, PiMU1-PiStdU1, PiMU1+PiStdU1, alpha=0.1)\n",
        "plt.plot(NN, PiMEps, label='$\\epsilon$-Greedy ', color='blue')\n",
        "plt.fill_between(NN, PiMEps-PiStdEps, PiMEps+PiStdEps, alpha=0.1, color='blue')\n",
        "\n",
        "plt.plot(NN, PiMEmp, label='Empirical', color='mediumpurple')\n",
        "plt.fill_between(NN, PiMEmp-PiStdEmp, PiMEmp+PiStdEmp, alpha=0.1, color='mediumpurple')\n",
        "# plt.plot(NN, PiMEps2, label='$\\epsilon$-Greedy (0.1)')\n",
        "# plt.fill_between(NN, PiMEps2-PiStdEps2, PiMEps2+PiStdEps2, alpha=0.1)\n",
        "\n",
        "\n",
        "plt.plot(NN, optimum, 'k--', alpha=0.3)\n",
        "plt.xlabel('$n$', fontsize=24, fontweight='bold')\n",
        "plt.ylabel('$\\pi_n(u)$', fontsize=24)\n",
        "\n",
        "if ToyModel=='1':\n",
        "  title = 'Synthetic Model I'\n",
        "else:\n",
        "  title = 'Synthetic Model II'\n",
        "\n",
        "plt.title(title, fontsize=20)\n",
        "\n",
        "plt.legend(fontsize=16)\n",
        "if ToyModel=='1':\n",
        "  figname='Expt0_first_model.png'\n",
        "else:\n",
        "  figname='Expt0_second_model.png'\n",
        "plt.xticks(fontsize=14, fontweight='bold')\n",
        "plt.yticks(fontsize=14, fontweight='bold')\n",
        "plt.tight_layout()\n",
        "\n",
        "plt.show()\n",
        "# plt.savefig(figname, dpi=450)\n",
        "# files.download(figname) "
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "VAYzGCNbNGbX"
      },
      "source": [
        "To show that with a wrong choice of $c$ for the UCB algorithm, we still get asymptotic convergence. Whereas a wrong choice in the $\\epsilon$-greedy strategy may lead to $\\Omega(1)$ excess risk. \n",
        "\n",
        "1. UCB with param 1.0 and n=5000 \n",
        "2. UCB with param 2.0 and n=10000"
      ]
    }
  ]
}