{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "d39948b2",
   "metadata": {},
   "source": [
    "# Asymptotic normality - one dimension examples"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "363c6954",
   "metadata": {},
   "source": [
    "## Two-armed bandit  and AR(1) model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "faae7111",
   "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": "31ccfacc",
   "metadata": {},
   "source": [
    "## Two-armed bandit with $\\epsilon$-Greedy algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ba583b0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# define reward function\n",
    "def reward():\n",
    "    # true signal 0.3\n",
    "    return  0.3 + np.random.poisson(1,1)[0] - 1\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": "bb663630",
   "metadata": {},
   "source": [
    "### Histogram of $\\frac{S_{11}}{n}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c990aa46",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([267., 121.,  63.,  40.,  40.,  33.,  50.,  62., 154., 170.]),\n",
       " array([ 92. , 174.2, 256.4, 338.6, 420.8, 503. , 585.2, 667.4, 749.6,\n",
       "        831.8, 914. ]),\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": "5d8a859f",
   "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": "e2f39519",
   "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": 14,
   "id": "c837d052",
   "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": "iVBORw0KGgoAAAANSUhEUgAAAcwAAAFcCAYAAABFvY7FAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABiFUlEQVR4nO3deVxU9f7H8Rf7IgiCqKCCK7gvpOKeoqllLrlluaSZbeq9+as0bbGyrmaW3dS6ddMsJTW1cF9xF1FxX3CX3YV93zm/PybmSjAwrGeAz/Px4CGe9T3DmfnMOfM936+RoigKQgghhCiSsdoBhBBCiKpACqYQQgihBymYQgghhB6kYAohhBB6kIIphBBC6EEKphBCCKEHKZhCCCGEHqRgCiGEEHqQglkCOTk5akeoENX1cQkhRHkyiILp7e2Nh4dHoT+tW7emU6dOPPnkk0ydOhUfHx8SEhJ0bis8PFy77vr168sln6IobNmyhbfffrtU6+vKVBFZS6Kox6V2NjVdvnyZN954gx49etCuXTt69+7NggUL1I5V7dXkY64myHuff++999SOUmqmagcoTm5uLmlpaaSlpfHgwQP8/f1ZuXIlCxcuZMCAAZWS4d1332X79u1069atUvZXWarr4yqLO3fuMGHCBDIyMrTToqKisLa2VjGVEMIQGFTBfOKJJ/jvf/+bb1pOTg6pqalERERw5MgR1q5dS0xMDLNmzWLFihV4e3vnW97MzAxXV1cAbG1tyyXXw4cPy7R+RWQqD0U9LkPNXNG2bdumLZbvv/8+zzzzDEZGRpibm6ucrPqrqcecqDoMqmCamJhQq1atAtNr165NgwYNeOKJJxg2bBiTJ08mNjaW2bNns2vXLho2bKhdtn79+uzfv78yYxfLEDMVpypmLg/R0dEA2NvbM3nyZJXT1Cw19ZgTVYdBFUx9tGzZkqVLl/Lyyy+Tnp7OihUrWLRokdqxRDWR1wCqsA9uomYICQlh48aNBAQEEBoaSlpaGjY2Njg4ONCyZUvatm3LpEmT5DJ9DWQQjX5KqlevXvTo0QPQXEJLTEzUziuq4YCiKOzdu5c33niDXr160bZtW7p168bo0aNZtmyZ9uwiz/Lly/Hw8OD06dMAnD59WrvtU6dOFdjfnTt38PHxwdvbm/bt29O/f39WrFihd2OG+/fvM3/+fHr37k379u0ZMGAAn376KeHh4YUuf+rUKe12jx49qnO7ecssXbq0VI9LV+bjx4/zj3/8g759+9KuXTu8vLx44YUXWLNmDenp6YWu8/fnKyYmhsWLFzN48GA6dOhAt27deOmll9ixYwdlGXmupNkmTZqEh4cHf/75JwARERHanJMmTSrRvi9dusTcuXO1x0HXrl15/vnnWb16td7PS3HHka5lyvo8lGQfJX09FaeoY66yjpv//ve/PPPMM6xatYqrV6+SlJREdnY28fHx3L17l71797Jy5cpSXaLPzs5m27ZtTJw4kV69etGpUydGjhzJmjVryM7O5qOPPiq0UUxJ/+6lOf7KY/3c3Fx27drFpEmT6NmzJ507d2b06NFs2rRJ59/E19dXr/cwRVG0jYY+++yzYh9DRalyZ5h5hg4dysmTJ8nOzubUqVM89dRTxa7z3nvv4evrm29aQkICCQkJXLlyhXXr1vHTTz/RuXPnUmVat24dv/32m/b/kZGRODg46LVuUFAQy5Yty9cCODw8HB8fHzZv3szSpUsZNGhQqXKVt4yMDObMmcOePXvyTY+Pj+fcuXOcO3eOtWvX8v333+Pu7q5zOzdu3GDhwoXExsbm23ZAQAABAQEcO3aML774QpVspaEoCkuXLmXVqlX53iAyMzO5cOECFy5cYP369fzwww80a9ZM53b0OY6KW6Y8nofi9lHRryddKuK4Adi0aZP2Q2XLli0ZM2YMrVq1wtbWlvj4eB4+fMjly5dJT0/H1LRkb52pqanMnDmTEydO5JseFBREUFAQ+/btw8XFpdjtFPU3KevxV5b109LSmD17NocOHco3/cqVK3zwwQecPHmS3NzcAvscNGgQn3zyCampqezcuZO+ffsW+rjPnj1LREQEACNGjCjuaao4igHo37+/4u7urkycOFHvdYKCghR3d3fF3d1dWbx4sXZ6WFiYdvpvv/2mnb5jxw7t9IULFypBQUFKTEyMEhISovz6669Kp06dFHd3d2XQoEFKTk6OoiiKkpGRoSQnJysvvPCC4u7urrzwwgtKcnKykpycrGRnZxfYn7u7uzJu3DjlypUryoMHD5RNmzYpiYmJOjP9fd22bdsq3377rRIaGqpERUUpf/75p9KrVy/tvBs3buR7DgICArTrHjlyROdzlbfMl19+WarH9XhmRVGUWbNmaee98cYbypkzZ5TY2Fjl3r17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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-nonsubGaussian.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "88d63878",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "6d1c28b8",
   "metadata": {},
   "source": [
    "## AR(1) model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "5975667d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# generate data\n",
    "def AR(n):\n",
    "    x = np.zeros(n)\n",
    "    y = np.zeros(n)\n",
    "    noise_seq = np.random.poisson(1,n) - 1\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": "dd65b646",
   "metadata": {},
   "source": [
    "### Replications"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "34e77e6b",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(666)\n",
    "E1 = AR_repli(3000, 1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "84464cb6",
   "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.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-nonsubGaussian.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df7f7dc2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b6a2bc9",
   "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
}
