{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "1d6388c0",
   "metadata": {},
   "source": [
    "# Asymptotic normality - one dimension examples"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8142a775",
   "metadata": {},
   "source": [
    "## Two-armed bandit  and AR(1) model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1a077daa",
   "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": "1f0062fc",
   "metadata": {},
   "source": [
    "## Two-armed bandit with $\\epsilon$-Greedy algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "42216c59",
   "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": "a05c6a07",
   "metadata": {},
   "source": [
    "### Histogram of $\\frac{S_{11}}{n}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "491a4a12",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([236., 135.,  64.,  49.,  27.,  39.,  36.,  63., 155., 196.]),\n",
       " array([ 94., 176., 258., 340., 422., 504., 586., 668., 750., 832., 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": "d170a4cf",
   "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": "0fac7a48",
   "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": "b277cb51",
   "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-poisson.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2fa5b509",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "a1441b0b",
   "metadata": {},
   "source": [
    "## AR(1) model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "07a0fc87",
   "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)*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": "0ac7b947",
   "metadata": {},
   "source": [
    "### Replications"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b24da6f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(666)\n",
    "E1 = AR_repli(3000, 1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0e48febd",
   "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": "iVBORw0KGgoAAAANSUhEUgAAAcwAAAFZCAYAAAAVcB92AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABkoUlEQVR4nO3dd1yV5f/H8RcclgxBFBQxcKIm7r33yJHmSM001GxpfbWynNmwMisttXJnGmqZhltTnIgLN05cqICCMmSPw/n9ceL8JNYBDtwc+DwfDx7hfe5z3+9D55zPfV/3dV+XiUaj0SCEEEKIXJkqHUAIIYQwBlIwhRBCCD1IwRRCCCH0IAVTCCGE0IMUTCGEEEIPUjAVolarlY5QJErr6xJCiFJVMLt160bdunWz/alfvz5NmjShc+fOjB07Fm9vb2JiYvTa3pQpUwyWMSQkhHfffZczZ84U6PlbtmzRvaZbt27plj948EC3fMOGDYaKmy++vr6MHTs2y/KTJ0/qsh05ckSBZMrQaDR4e3vz0ksv0axZM5o0aUKPHj04evSo0tHKhGnTplG3bl3at2+vaI6hQ4fq3v/Lly/X6znPfs5z+qlXrx4NGzakU6dOvPbaa6xZs4bk5GS9tn/r1i0aN27MG2+8odf6v/32G3Xr1uW7777LcZ21a9dSt25d/vjjD722aYxKVcHMTXp6OomJiTx8+BB/f38+//xzXnjhBXx9fYstw/Xr1+nbty///PMPpe3214ULF/LOO+/w4MEDpaOUGIsXL+bzzz/nypUrxMfHk5iYyP3796lcubLS0UQxuXHjBpcuXdL9+48//iA9Pd0g29ZoNKSkpPDo0SNOnDjB119/zYABA3j06FGuz0tNTeXDDz8kLS2NadOm5bmf8+fPs2DBgjzXe+WVV6hVqxZff/01d+/e1fdlGBUzpQMUhebNm7NixYpMy9RqNQkJCYSEhHD48GHWrVvHkydPePfdd1myZAndunXLsh1XV1dUKhWVKlUySK7o6GiSkpIKtQ1bW1vc3NwAsLCwMEQsg8jtQ2plZaXLbG1tXVyRFPfXX38BULVqVRYuXEj16tVJSEigSpUqCicrGypWrIibmxuOjo6KZch4DzRu3JiLFy/y4MEDjh49SufOnfXexvLly2nRokWW5RqNhri4OC5fvszq1asJCAggODiY9957L9ezvDVr1nDlyhVGjRpFzZo1c913QEAAb775pl7fW2ZmZkydOpW33nqLTz/9lDVr1uT5HGNTKgumSqXCxsYmy/Ly5ctTpUoVmjdvzoABAxgzZgyRkZFMmTKFXbt24erqmmn9devWFVdkvfXq1YtevXopHSNfGjduzL59+5SOUeweP34MQJ8+fWjSpAkADg4OygUqY6ZOncrUqVMV239KSgrbtm0DoG/fvgBcuHCBDRs25KtgWllZZft9BtoD6CpVqtClSxfGjRvHiRMnOH/+PMePH6dt27ZZ1o+IiODnn3/G0tKSt99+O9f9rlmzhu+++47U1FS9s3bt2pXGjRtz/Phx9uzZQ58+ffR+rjEoM02y/1WnTh1de3xSUhJLlixROJEobTI6QJWls2rx/w4cOEBUVBQAHTt21BXNw4cPExoaatB9qVQq3nzzTd2/AwICsl1v2bJlJCQk0K9fP5ycnLJdJyAggGHDhvH111+TmppKgwYN8pXltddeA2DRokUGa34uKcpswQRo37697ihs27ZtPH36NNPjuXX6efToEd9++y0DBw6kSZMmNGrUiC5duvDee+9le120bt26jBkzRvfvMWPGULduXUaPHp1lfxs2bODUqVO89NJLeHp60rZtW9555x3S09Nz7PTzX2FhYcyYMYMOHTrQsGFDunfvzueff57jNUZ9Okhkt++MZX///Teg7dSUsc6WLVsA/Tr9XLhwgY8//phu3brRsGFDWrRoweDBg1myZEmOnbMWL15M3bp1efnll3X7mTRpEu3bt8fT05MuXbowffr0XP9O+shPtmc7X2VYsmRJlr+Jvh49esQ333xD//79adq0KU2aNKFv37588803OTaDZ/w/ad++PcnJyXzxxRe0bt1a99z9+/cD+r3fMqSkpLBp0ya8vLxo3bo1np6edOjQgbfeeos9e/bkeE1e330kJSXx22+/MWrUKFq0aIGnpyft2rXTddDTtzPLs3J6Tz/79wG4evUqU6dOpVOnTrrXNXnyZC5cuJDvfT4rozm2Tp061KpVi/79+6NSqUhPTy+SjjHPXhuPiIjI8nh0dDR//vkngO4zk5233nqLixcvYmpqyujRo1m/fn2+cvTs2RMHBwdu3bpVrH1EikOpbJLNj379+nH8+HHS0tI4efIkPXv2zPM5gYGBjBs3LsuXZVhYGGFhYezdu5d+/frx3XffYWqa/2OSwMBAvvrqK1JSUgCIjIzEwsJC721dvXqVhQsXZsr34MEDvL29+euvv/juu+9KTLOuRqPhyy+/zNL8nZKSwuXLl7l8+TK///47ixYtolWrVjlu55dffuHHH3/M9MUdFhbGli1b2L59O7/88gsdO3ZUJFtB7dmzh2nTppGYmJhp+a1bt7h16xYbN27k22+/pUePHjluY+rUqezduzfTc2vUqJFpnbzeb/fv32fixIlcv3490/MiIiI4ePAgBw8epH379vzwww+UL18+2xy57SMmJoYxY8Zw7dq1TM958uQJ/v7++Pv7s2HDBtauXWvw65F///03s2fPztTsGBERwe7du9mzZw9z585l6NCh+d7uw4cPOXbsGAD9+/cHoFKlSnTo0IHDhw/z119/MWnSJMzNzQ3zQoCbN2/qfnd2ds7y+N9//01ycjKVK1emadOmOW7HxMSEDh068P777+f77BK0fSu6devGli1b2LBhg17fqcaiTJ9hAjRs2FD3+9mzZ/NcX6PRMHXqVGJiYnB3d2fRokUcOHCA48ePs379et1R686dO9m+fXumbT/bpXz58uWcPXs2S+ck0B6Zli9fnmXLluHv78+KFSt4/fXX9X5Nf/zxBwkJCUyaNIn9+/dz7NgxvvnmG5ycnEhOTub999/nxo0bem8vNy+++CJnz55lwIABgLaDy9mzZzl79iwvvvhins+fP3++riA1b96c1atXc/z4cXx9fZk1axb29vZERUUxYcKELF+oGW7cuMEPP/xAgwYNWLZsGcePH2f//v28/fbbmJqakpqayuzZs/N9j2hBsrm6uupef4Y333wzX38TgOPHjzNlyhQSExPx8PBg0aJF+Pn5cezYMZYsWYKHhwcJCQn873//y/F9+/jxY/bu3cuQIUPw9fXln3/+Ye7cudSqVSvTerm932JiYhg/fjzXr19HpVIxbtw4tm/fzsmTJ/nrr7946aWXADh27BgTJ04kLS0t2yy57eP777/n2rVrlCtXjlmzZrF3715OnjzJ9u3bdS0wQUFBfP/993r97fQVExPDrFmzcHV1ZeHChfj5+XH48GGmT5+OpaWl7oApOjo639vesmUL6enpmJqaMnDgQN3yQYMGAdr/N4a8rp+YmMiyZct0/+7evXuWdXbu3AlAhw4dct3Wn3/+yapVqwpULDNk7OPEiRNERkYW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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-poisson.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7159d3eb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ffde9e49",
   "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
}
