{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "67b99746",
   "metadata": {},
   "source": [
    "# Asymptotic normality - one dimension examples"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f041db6e",
   "metadata": {},
   "source": [
    "## Two-armed bandit  and AR(1) model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e0084467",
   "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": "d45cd4e7",
   "metadata": {},
   "source": [
    "## Two-armed bandit with $\\epsilon$-Greedy algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "289ba3d7",
   "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": "d31f0b60",
   "metadata": {},
   "source": [
    "### Histogram of $\\frac{S_{11}}{n}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "01ddc019",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([254., 120.,  59.,  38.,  39.,  37.,  30.,  51., 143., 229.]),\n",
       " array([ 96. , 177.2, 258.4, 339.6, 420.8, 502. , 583.2, 664.4, 745.6,\n",
       "        826.8, 908. ]),\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": "50c36a51",
   "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": "982cbf15",
   "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": "4819e337",
   "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": "af263d9a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "aad16e62",
   "metadata": {},
   "source": [
    "## AR(1) model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "8b8c16f2",
   "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)*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": "7ed5fbab",
   "metadata": {},
   "source": [
    "### Replications"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "49b6cd59",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(666)\n",
    "E1 = AR_repli(3000, 1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "7f28d617",
   "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": "iVBORw0KGgoAAAANSUhEUgAAAcwAAAFZCAYAAAAVcB92AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABlAElEQVR4nO3deVhUZf/H8TcM+yKC4i5oKi7gvoFb7pm7lVma5lqm1pNPWlmWmZllLk9qq2ml4pJp7jtuKaDiguKCiooCLmyy78zvj/kxQWwDDBwGvq/rmks4c+acz+DMfOfc577vY6RWq9UIIYQQokDGSgcQQgghDIEUTCGEEEIHUjCFEEIIHUjBFEIIIXQgBVMIIYTQgRRMhWRkZCgdoVRU1OclhBAVqmD27t2bpk2b5nlr3rw5bdq04dlnn2XChAl4enoSExOj0/Zmzpypt4yhoaG8/fbbnD9/vliP3759u/Y5BQUFaZeHhIRol2/atElfcYvEy8uLCRMm5Fp+5swZbbaTJ08qkEwZarUaT09PRowYQbt27WjTpg19+/bl77//VjpapfDhhx/StGlTunbtqmiOl156Sfv6//nnn3V6TPb3eX63Zs2a0bJlS3r06MHrr7/Ob7/9RkpKik7bDwoKonXr1rzxxhs6rf/777/TtGlTlixZku8669ato2nTpmzZskWnbRqiClUwC5KZmUlSUhKPHj3C29ubzz//nOeffx4vL68yyxAYGMjAgQM5dOgQFW346/Lly5k2bRohISFKRyk3Vq5cyeeff861a9dISEggKSmJBw8eULNmTaWjiTJy8+ZNrly5ov19y5YtZGZm6mXbarWa1NRUHj9+jK+vL4sWLWLIkCE8fvy4wMelpaUxa9Ys0tPT+fDDDwvdz6VLl1i2bFmh640ePZpGjRqxaNEi7t27p+vTMCgmSgcoDe3bt2f16tU5lmVkZJCYmEhoaCgnTpxg/fr1REZG8vbbb7Nq1Sp69+6dazt169ZFpVJRvXp1veR6+vQpycnJJdqGjY0NTk5OAJiZmekjll4U9Ca1sLDQZraysiqrSIr7888/AahTpw7Lly+nQYMGJCYmUqtWLYWTVQ7VqlXDyckJBwcHxTJkvQZat27N5cuXCQkJ4e+//+bZZ5/VeRs///wzHTp0yLVcrVYTHx/P1atXWbt2LX5+fgQHB/POO+8UeJT322+/ce3aNcaMGcMzzzxT4L79/Px48803dfrcMjExYfbs2UydOpXPPvuM3377rdDHGJoKWTBVKhXW1ta5llepUoVatWrRvn17hgwZwrhx44iKimLmzJns27ePunXr5lh//fr1ZRVZZ/3796d///5KxyiS1q1bc/jwYaVjlLmIiAgABgwYQJs2bQCoWrWqcoEqmdmzZzN79mzF9p+amsquXbsAGDhwIAD+/v5s2rSpSAXTwsIiz88z0HyBrlWrFj179mTixIn4+vpy6dIlfHx88PDwyLV+eHg433//Pebm5rz11lsF7ve3335jyZIlpKWl6Zy1V69etG7dGh8fHw4cOMCAAQN0fqwhqDRNsv/WpEkTbXt8cnIyq1atUjiRqGiyOkBVpqNq8Y+jR48SHR0NQPfu3bVF88SJE4SFhel1XyqVijfffFP7u5+fX57r/fTTTyQmJjJo0CAcHR3zXMfPz4+RI0eyaNEi0tLScHV1LVKW119/HYAVK1borfm5vKi0BROga9eu2m9hu3btIjY2Nsf9BXX6efz4Md988w3Dhg2jTZs2tGrVip49e/LOO+/keV60adOmjBs3Tvv7uHHjaNq0KWPHjs21v02bNnH27FlGjBiBm5sbHh4eTJs2jczMzHw7/fzbw4cP+eijj+jWrRstW7akT58+fP755/meY9Slg0Re+85a9tdffwGaTk1Z62zfvh3QrdOPv78/H3zwAb1796Zly5Z06NCBF154gVWrVuXbOWvlypU0bdqUl19+WbufGTNm0LVrV9zc3OjZsydz5swp8O+ki6Jky975KsuqVaty/U109fjxY77++msGDx5M27ZtadOmDQMHDuTrr7/Otxk86/+ka9eupKSksGDBAjp37qx97JEjRwDdXm9ZUlNT2bp1K+PHj6dz5864ubnRrVs3pk6dyoEDB/I9J6/rPpKTk/n9998ZM2YMHTp0wM3NjS5dumg76OnamSW7/F7T2f8+ANevX2f27Nn06NFD+7zeffdd/P39i7zP7LKaY5s0aUKjRo0YPHgwKpWKzMzMUukYk/3ceHh4eK77nz59yh9//AGgfc/kZerUqVy+fBljY2PGjh3Lxo0bi5SjX79+VK1alaCgoDLtI1IWKmSTbFEMGjQIHx8f0tPTOXPmDP369Sv0MQEBAUycODHXh+XDhw95+PAhBw8eZNCgQSxZsgRj46J/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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": "9770e8f5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22654057",
   "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
}
