{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "9f61e127",
   "metadata": {},
   "source": [
    "# Asymptotic normality - one dimension examples"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "07ed6b75",
   "metadata": {},
   "source": [
    "## Two-armed bandit  and AR(1) model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "bbb567ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from sklearn.linear_model import LinearRegression\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from scipy.stats import norm\n",
    "import pandas as pd\n",
    "import scipy"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "17b7b3c5",
   "metadata": {},
   "source": [
    "## Two-armed bandit with $\\epsilon$-Greedy algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "6a2be620",
   "metadata": {},
   "outputs": [],
   "source": [
    "# define reward function\n",
    "def reward():\n",
    "    # true signal 0.3\n",
    "    return  0.3 + np.random.normal(0,1,1)[0]\n",
    "\n",
    "\n",
    "# define function for generating predictable weights w_t\n",
    "def f(x):\n",
    "    return 1/np.sqrt(x*np.log(np.exp(2)*x)*np.log(np.log(np.exp(2)*x))**2)\n",
    "\n",
    "\n",
    "# define eps Greedy algorithm\n",
    "def ECB(n):\n",
    "    rewards_seq = np.array([reward() for i in range(n)])\n",
    "    x = [0, 1]\n",
    "    y = [rewards_seq[0], rewards_seq[1]]\n",
    "    nums = np.array([1 , 1 ])\n",
    "    rewards = np.array(y)\n",
    "    \n",
    "    for i in range(n-2):\n",
    "        # compute arm means\n",
    "        arm_means = rewards/nums\n",
    "        arm = np.argmax(arm_means)\n",
    "        flag = np.random.uniform(0,1,1)[0]\n",
    "        # defining decaying rate\n",
    "        if flag > 1 - np.log(i+1)**0.5/np.sqrt(i+1) and i>50:\n",
    "            arm = 1 - arm\n",
    "        x.append(arm)\n",
    "        newr = rewards_seq[i+2]\n",
    "        y.append(newr)\n",
    "        nums[arm] += 1\n",
    "        rewards[arm] += newr\n",
    "    # return the noise sequence\n",
    "    return x, y, rewards_seq - 0.3\n",
    "\n",
    "# Generate the histogram of the fraction of the number of first arm pulled to the total number of runs\n",
    "def ECB_hist():\n",
    "    n = 1000\n",
    "    rewards_seq = np.array([reward() for i in range(n)])\n",
    "    x = [0, 1]\n",
    "    y = [rewards_seq[0], rewards_seq[1]]\n",
    "    nums = np.array([1 , 1 ])\n",
    "    rewards = np.array(y)\n",
    "    for i in range(n-2):\n",
    "        arm_means = rewards/nums\n",
    "        arm = np.argmax(arm_means)\n",
    "        flag = np.random.uniform(0,1,1)[0]\n",
    "        if flag > 1 - np.log(i+1)**0.5/np.sqrt(i+1) and i>50:\n",
    "            arm = 1 - arm\n",
    "        x.append(arm)\n",
    "        newr = rewards_seq[i+2]\n",
    "        y.append(newr)\n",
    "        nums[arm] += 1\n",
    "        rewards[arm] += newr\n",
    "    return np.sum(np.array(x))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ca145873",
   "metadata": {},
   "source": [
    "### Histogram of $\\frac{S_{11}}{n}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "31552d0c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([221., 130.,  64.,  39.,  42.,  39.,  43.,  56., 124., 242.]),\n",
       " array([ 96. , 177.4, 258.8, 340.2, 421.6, 503. , 584.4, 665.8, 747.2,\n",
       "        828.6, 910. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p = []\n",
    "for i in range(1000):\n",
    "    p.append(ECB_hist())\n",
    "plt.hist(np.array(p))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "8fbe025a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# define erros\n",
    "def scaled_estimators(n,sampler):\n",
    "    x,y,noise = sampler(n)\n",
    "    X = np.zeros((n,2))\n",
    "    # construct X\n",
    "    X[:,0] = (np.array(x) == 0) - 0\n",
    "    X[:,1] = (np.array(x) == 1) - 0\n",
    "    # y\n",
    "    y = np.array(y)\n",
    "    \n",
    "    # compute OLS\n",
    "    M = LinearRegression( fit_intercept = False).fit(X, y)\n",
    "    coeff = M.coef_\n",
    "    coeff = coeff[0]\n",
    "    Sn = X.T@X\n",
    "    Sn = Sn[0,0]\n",
    "    \n",
    "    # standardize errors for ols\n",
    "    ols = np.sqrt(Sn)*(coeff - 0.3)\n",
    "    \n",
    "    # extract information for the first arm\n",
    "    ysub = y[np.array(x) == 0]\n",
    "    noise_sub = noise[np.array(x) == 0]\n",
    "    n1 = len(ysub)\n",
    "    \n",
    "    # define s0\n",
    "    s0 = np.exp(2)*np.log(n)\n",
    "    w = []\n",
    "    \n",
    "    # compute weights w\n",
    "    # consider self-scaled version\n",
    "    for i in range(n1):\n",
    "        w.append(f(1 + (i+1)/s0)/np.sqrt(s0))\n",
    "    w = np.array(w)\n",
    "    \n",
    "    # equivalent form for standardized residual\n",
    "    # factor 1/np.sqrt(np.sum(w**2)) is used to stablize the variance\n",
    "    alee = 1/np.sqrt(np.sum(w**2))*np.sum(w*noise_sub)\n",
    "    \n",
    "    return np.array([ols, alee]).reshape(1,2)\n",
    "    \n",
    "#   replication function\n",
    "def scaled_repli(N , n,  sampler):\n",
    "    E = np.zeros((N,2))\n",
    "    for i in range(N):\n",
    "        E[i,:] = scaled_estimators(n,sampler)\n",
    "    return E"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7ea08cce",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(666)\n",
    "# 3000 replications with n = 1000\n",
    "E = scaled_repli(3000, 1000, ECB)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "71bfe6f3",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/mufangying/opt/anaconda3/lib/python3.8/site-packages/seaborn/distributions.py:2551: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(rc={'figure.figsize':(8,5)})\n",
    "sns.set_style(\"white\")\n",
    "#sns.histplot(E[:,0], label = 'OLS', stat = 'density', kde = True, line_kws = {'lw': 5.5} , lw = 1.5)\n",
    "sns.distplot(E[:,0],  norm_hist=True,  kde=False, label=\"OLS\",   bins=int(180/5), color = 'darkblue', \\\n",
    "             hist_kws={'edgecolor':'black'}, kde_kws={'linewidth': 3})\n",
    "sns.distplot(E[:,1], norm_hist=True,  kde=False, label=\"ALEE\", bins=int(180/5), color = 'green', \\\n",
    "             hist_kws={'edgecolor':'black'},kde_kws={'linewidth': 3})\n",
    "plt.plot(np.arange(-4, 4, 0.01), norm.pdf(np.arange(-4, 4, 0.01), 0, 1), \\\n",
    "         label = r'$\\mathcal{N}(0,1)$', c = \"black\", lw=2.5)\n",
    "plt.ylabel('')\n",
    "\n",
    "plt.legend(prop={'size': 20})\n",
    "plt.yticks([], [])\n",
    "plt.xticks(fontsize = 18)\n",
    "plt.xlim(-4.3,4.3)\n",
    "plt.title(r'Distribution of errors in $\\epsilon$-greedy', fontsize = 28, y = 1.02)\n",
    "plt.savefig('Bandit-ECB-OLS-ALEE.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e8b4c3e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "4a69847e",
   "metadata": {},
   "source": [
    "## AR(1) model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "798cae89",
   "metadata": {},
   "outputs": [],
   "source": [
    "# generate data\n",
    "def AR(n):\n",
    "    x = np.zeros(n)\n",
    "    y = np.zeros(n)\n",
    "    noise_seq = np.random.normal(0,1,n)\n",
    "    for i in range(n):\n",
    "        y[i] = x[i] + noise_seq[i]\n",
    "        if i < n -1:\n",
    "            x[i+1] = y[i]\n",
    "    return x,y,noise_seq\n",
    "\n",
    "def AR_scaled_estimators(n):\n",
    "    x,y,noise_seq = AR(n)\n",
    "    X = x.reshape(-1,1)\n",
    "\n",
    "    # compute OLS\n",
    "    M = LinearRegression( fit_intercept = False).fit(X, y)\n",
    "    coeff = M.coef_\n",
    "    coeff = coeff[0]\n",
    "    Sn = X.T@X\n",
    "    Sn = Sn[0,0]\n",
    "   \n",
    "    ols = np.sqrt(Sn)*(coeff - 1)\n",
    "    \n",
    "    s0 = np.exp(2)*n/np.log(np.log(n))\n",
    "    w = []\n",
    "    \n",
    "    # consider f2 to compute weights w\n",
    "    for i in range(n):\n",
    "        w.append(f(1 + np.sum(x[:(i+1),]**2)/s0)*x[i]/np.sqrt(s0))\n",
    "    w = np.array(w)\n",
    "\n",
    "    # scale the variance\n",
    "    alee = 1/np.sqrt(np.sum(w**2))*np.sum(w*noise_seq)\n",
    "    \n",
    "    return np.array([ols, alee]).reshape(1,2)\n",
    "    \n",
    "\n",
    "def AR_repli(N , n):\n",
    "    E = np.zeros((N,2))\n",
    "    for i in range(N):\n",
    "        E[i,:] = AR_scaled_estimators(n)\n",
    "    return E"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a89158d4",
   "metadata": {},
   "source": [
    "### Replications"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f0518b88",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(666)\n",
    "E1 = AR_repli(3000, 1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "656f554d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/mufangying/opt/anaconda3/lib/python3.8/site-packages/seaborn/distributions.py:2551: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAcwAAAFZCAYAAAAVcB92AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABk+UlEQVR4nO3dd1gUZ9fA4R8sTYogigUUrNg1drEr9hI1iTHRV2NNjCVvjDGJianGGI3ljSVFY4ndGA32EnsBC/YGdkRARUB6Xfb7Yz82ENoCC8PCua9rL2H2mZkzOLtn5pmnmGg0Gg1CCCGEyJGp0gEIIYQQxkASphBCCKEHSZhCCCGEHiRhCiGEEHqQhCmEEELoQRKmQtRqtdIhFIqSelxCCFGiEma3bt2oW7dulq/69evz0ksv0blzZ0aPHs2GDRuIjIzUa3tTp041WIxBQUFMmTKFCxcu5Gv97du3647p3r17uuWPHz/WLd+0aZOhws2Tw4cPM3r06EzLz549q4vtxIkTCkSmDI1Gw4YNGxg8eDDNmzfnpZdeonv37pw8eVLp0EqFTz75hLp169K+fXtF43jttdd05//y5cv1Wif95zy7V7169WjcuDGdOnXirbfeYs2aNSQmJuq1/Xv37tG0aVPefvttvcr//vvv1K1bl/nz52dbZu3atdStW5ctW7botU1jVKISZk5SU1OJj4/nyZMneHt7880339CnTx8OHz5cZDH4+/vTt29fDh48SEnr/rpo0SImTpzI48ePlQ6l2FiyZAnffPMNN2/eJDY2lvj4eAIDA6lUqZLSoYkicvv2ba5du6b7fcuWLaSmphpk2xqNhqSkJJ4+fcqZM2eYM2cOAwYM4OnTpzmul5yczIcffkhKSgqffPJJrvu5fPkyCxcuzLXcsGHDqFWrFnPmzOHhw4f6HoZRMVM6gMLQokULVqxYkWGZWq0mLi6OoKAgjh8/zrp16wgLC2PKlCksXbqUbt26ZdqOi4sLKpWKChUqGCSuFy9ekJCQUKBt2Nra4urqCoCFhYUhwjKInD6kVlZWupitra2LKiTF/fnnnwA4OzuzaNEiqlevTlxcHJUrV1Y4stKhfPnyuLq64ujoqFgMaedA06ZNuXr1Ko8fP+bkyZN07txZ720sX76cli1bZlqu0WiIiYnhxo0brFq1Cl9fXwICAnjvvfdyvMtbs2YNN2/eZPjw4dSsWTPHffv6+vLOO+/o9b1lZmbG9OnTmTBhAl999RVr1qzJdR1jUyITpkqlwsbGJtPysmXLUrlyZVq0aMGAAQMYOXIk4eHhTJ06lb179+Li4pKh/Lp164oqZL317NmTnj17Kh1GnjRt2pS///5b6TCK3PPnzwHo3bs3L730EgAODg7KBVTKTJ8+nenTpyu2/6SkJHbu3AlA3759Abhy5QqbNm3KU8K0srLK8vsMtBfQlStXpkuXLowZM4YzZ85w+fJlfHx88PDwyFQ+NDSUn376CUtLS959990c97tmzRrmz59PcnKy3rF27dqVpk2b4uPjw/79++ndu7fe6xqDUlMl+2916tTR1ccnJCSwdOlShSMSJU1aA6jSdFct/nHkyBEiIiIA6Nixoy5pHj9+nODgYIPuS6VS8c477+h+9/X1zbLcr7/+SlxcHP369cPJySnLMr6+vgwZMoQ5c+aQnJxMw4YN8xTLW2+9BcDixYsNVv1cXJTahAnQvn173VXYzp07iYqKyvB+To1+nj59yg8//MDAgQN56aWXaNKkCV26dOG9997L8rlo3bp1GTlypO73kSNHUrduXUaMGJFpf5s2beLcuXMMHjyYRo0a4eHhwcSJE0lNTc220c+/hYSE8Omnn9KhQwcaN26Mp6cn33zzTbbPGPVpIJHVvtOW/fXXX4C2UVName3btwP6Nfq5cuUKH3/8Md26daNx48a0bNmSV155haVLl2bbOGvJkiXUrVuX119/XbefyZMn0759exo1akSXLl2YMWNGjn8nfeQltvSNr9IsXbo0099EX0+fPmXu3Ln079+fZs2a8dJLL9G3b1/mzp2bbTV42v9J+/btSUxMZNasWbRp00a37qFDhwD9zrc0SUlJbN26lVGjRtGmTRsaNWpEhw4dmDBhAvv378/2mby++0hISOD3339n+PDhtGzZkkaNGtGuXTtdAz19G7Okl905nf7vA3Dr1i2mT59Op06ddMf1/vvvc+XKlTzvM7206tg6depQq1Yt+vfvj0qlIjU1tVAaxqR/Nh4aGprp/RcvXvDHH38A6D4zWZkwYQJXr17F1NSUESNGsHHjxjzF0aNHDxwcHLh3716RthEpCiWySjYv+vXrh4+PDykpKZw9e5YePXrkus7169cZM2ZMpi/LkJAQQkJCOHDgAP369WP+/PmYmub9muT6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JMNMS7Vy5Urds+p27drRvXt34uLiuHjxIt9//z0rV65k6dKlvPTSS/neR1xcHKNGjeLKlSs0bdqUl19+GSsrKwICAti5cyc7duxg9uzZigyGXtQkYQrFBQeH6ZUIjx07UwTR5F1YSBg7ftoBgFNVJwZNGqRsQGifZ65atYpGjRoRHx/P22+/zeXLl7G0tFQ6tEKn7/mklICAgwbZzoYNG5g3bx61a9fmxx9/pHbt2hne3717N59++ikjR45k27Zt1KlTJ1/7WblyJVeuXGHGjBmZphO7c+cOb7zxBl9++SUdO3akQoUK+T0coyBVskIUgEajYdPcTbqq2OGfDsfCykLhqLRq1qzJV199BYCfn5/ek/+K4u/Zs2d8//33ODg4sGrVqkzJEqB///7MmjWLxMREZsyYke99HT16FDMzM4YPH57pvTp16jB8+HASExM5fvx4vvdhLCRhClEAFw5d4Nop7bx/HgM8DD6ST0F98MEHuuq47777jlu3bikbkDCILVu2kJSUxLBhw6hUqVK25QYOHEjdunW5du0a169fz9e+UlJSSElJyXYEqddff51ly5bh4eGRr+0bE0mYQuRTUkISf/7vT0A7IPpr/31N4YgyMzMzY8WKFZiampKcnMzUqVNlQIMSwNvbG4BOnTrlWrZHjx4AHDp0KJeSWUsb0H/06NH88ssvmRJn1apV6d69O87OzvnavjGRhClEPh1cd5CIp9q5LQdNGqRYq9jctGzZkrfffhuAAwcOsG/fPoUjEgX14IG2gVlan9uc1KpVC4DAwMB87WvSpEk0adKEsLAwFi1aRJ8+fejYsSPTpk1jx44dparbkiRMIfIh4mkEB34/AEA192q0G9BO4Yhy9s0331C2bFlAW02bnJyscESiINLGCra1zf0izd7eHoAXL17ka1+2trZs3LiRL774goYNGwLaZ6i7d+/mo48+wtPTkz179uRr28ZGEqYQ+fDX0r9ISkgCYMgHQzBVFe+PkpOTE1988QUA/v7+/PTTTwpHJAoi7eInISEh17Lx8doxjcuVK5fv/ZmbmzN8+HC2b9/OqVOnmD9/Pq+88goODg5EREQwbdo0jh07lu/tGwvpViJKvaNnNhMZH5pjmcjIB3w27wW+V3zBGc7uOwtAs67NqNtS/w7gSpoyZQq//PILd+/e5euvv+att97CwcFB6bBEPri6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\n",
      "text/plain": [
       "<Figure size 576x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(rc={'figure.figsize':(8,5)})\n",
    "sns.set_style(\"white\")\n",
    "sns.distplot(E1[:,0],  norm_hist=True,  kde=False, label=\"OLS\",   bins=int(180/5), color = 'darkblue', \\\n",
    "             hist_kws={'edgecolor':'black'}, kde_kws={'linewidth': 3})\n",
    "sns.distplot(E1[:,1], norm_hist=True,  kde=False, label=\"ALEE\", bins=int(180/5), color = 'green', \\\n",
    "             hist_kws={'edgecolor':'black'},kde_kws={'linewidth': 3})\n",
    "plt.plot(np.arange(-4, 4, 0.01), norm.pdf(np.arange(-4, 4, 0.01), 0, 1), label = r'$\\mathcal{N}(0,1)$', c = \"black\", lw=2.5)\n",
    "plt.ylabel('')\n",
    "\n",
    "plt.legend(prop={'size': 20})\n",
    "plt.yticks([], [])\n",
    "plt.xticks(fontsize = 18)\n",
    "plt.xlim(-4.3,4.3)\n",
    "plt.title('Distribution of errors in AR(1)', fontsize = 28, y = 1.02)\n",
    "plt.savefig('AR1-OLS-ALEE.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3cc75b95",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbacbe39",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
