{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "999dbb9f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\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\n",
    "from scipy.stats import chi2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5524254b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# define reward function\n",
    "def get_noise():\n",
    "    return  np.random.poisson(1,1)[0] - 1\n",
    "\n",
    "\n",
    "def get_unitv(d):\n",
    "    # generate unit vector in sphere\n",
    "    x = np.random.normal(0,1,d)\n",
    "    return x/np.linalg.norm(x)\n",
    "\n",
    "def get_Actions(num,d):\n",
    "    return np.array([get_unitv(d) for i in range(num)])\n",
    "    \n",
    "\n",
    "# stochastic regression\n",
    "def ECB(n, Actions):\n",
    "    d = Actions.shape[1]\n",
    "    initial_run = Actions.shape[0]\n",
    "    theta = np.array([0.3]*d).reshape(-1,1)\n",
    "    \n",
    "    # data matrix\n",
    "    X = Actions.copy()\n",
    "    \n",
    "    # contextual bandits - action set\n",
    "    y = X@theta + np.array([get_noise() for i in range(initial_run)]).reshape(-1,1)\n",
    "    \n",
    "    y = y.reshape(-1)\n",
    "    nums = np.ones(initial_run)\n",
    "    rewards = y.copy().reshape(-1)\n",
    "    \n",
    "    for i in range(n-initial_run):\n",
    "        arm_means = rewards/nums\n",
    "        arm = np.argmax(arm_means)\n",
    "        # defining decaying rate\n",
    "        flag = np.random.uniform(0,1,1)[0]\n",
    "        if flag > np.log(i+1)**2/(i+1) and i > 50:\n",
    "            arm = np.random.randint(1,1+ initial_run) - 1\n",
    "        \n",
    "        # append new observation\n",
    "        newx = Actions[arm,:]\n",
    "        X = np.append(X, newx.reshape(1,-1), axis = 0 )\n",
    "        newr = np.sum(newx*0.3)  + get_noise()\n",
    "        y = np.append(y, newr)\n",
    "        \n",
    "    return X, y"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "965cb60a",
   "metadata": {},
   "source": [
    "## $\\Sigma_0 = \\log(n)$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5c0d09f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def Volumn(V):\n",
    "    # given a matrix V, compute the volumn correspoing to the ellipse of the format x^T V x \\leq 1\n",
    "    # universal constant are dropped\n",
    "    s =  np.linalg.svd(V)[1]\n",
    "    return 1/np.product(np.sqrt(s))\n",
    "\n",
    "\n",
    "\n",
    "def scaled_estimators(n, Actions, wlam, clam, sampler, alpha_list): # need to add lambda as tuning parameter here. \n",
    "    \n",
    "    d = Actions.shape[1]\n",
    "    # consider confidence level \n",
    "    siglevel = 1 - alpha_list \n",
    "    siglevelLen = np.size(siglevel)\n",
    "    cql = chi2.ppf(siglevel, d)\n",
    "    \n",
    "    true_theta = np.array([0.3]*d).reshape(-1,1)\n",
    "    CI_data = np.zeros((2, siglevelLen * 4 )) # first row is coverage and second row is volume. Times 4 means 4 methods\n",
    "    # OLS, W decor, concentration and ALEE (asymptotic) \n",
    "    \n",
    "    X,y = sampler(n, Actions)\n",
    "    #######################################\n",
    "    # compute OLS\n",
    "    M = LinearRegression(fit_intercept = False).fit(X, y)\n",
    "    coeff = M.coef_.copy().reshape(-1,1)\n",
    "    Sn = X.T@X\n",
    "    residual = y.reshape(-1,1) - X@coeff\n",
    "    # compute residual and use it as an estimate of sigma^2\n",
    "    sig_h = np.sqrt(np.mean(residual**2))\n",
    "    \n",
    "    c = 1/sig_h**2*(coeff.reshape(1,-1)- true_theta.reshape(1,-1))@Sn@(coeff - true_theta)\n",
    "    c = c.reshape(-1)[0]\n",
    "    \n",
    "    for i in range(siglevelLen): # is the number of significance level \n",
    "        cq = cql[i]\n",
    "        cover = c < cq - 0\n",
    "        v = Volumn(Sn/sig_h**2/cq)\n",
    "        v = np.log(v)\n",
    "        CI_data[:,0 + 4*i] = np.array([cover, v]).reshape(-1)  # coverage values grouped by significance levels \n",
    "     \n",
    "    #######################################\n",
    "    # W-decorrelation\n",
    "    W_lambdas = np.ones(n)*wlam\n",
    "    wols = M.coef_.copy().reshape(-1)\n",
    "    w = np.zeros((d,1))\n",
    "    WX = np.zeros((d,d))\n",
    "    W = np.zeros_like(X)\n",
    "    for t in range(n):\n",
    "        w = (np.eye(d) - WX)@X[t,:].reshape(-1,1) \n",
    "        w = w/(np.sum(X[t,:]**2) + W_lambdas[t])\n",
    "        W[t, :] = w.reshape(-1)\n",
    "        wols += w.reshape(-1) * (y[t] - np.sum(X[t,:]*coeff.reshape(-1)) ) \n",
    "        WX = WX + w@X[t,:].reshape(1,-1)\n",
    "        \n",
    "    WW = np.linalg.inv(W.T@W)\n",
    "   \n",
    "    # compute statistic\n",
    "    c = 1/sig_h**2*(wols - true_theta.reshape(1,-1))@WW@(wols.reshape(-1,1) - true_theta)\n",
    "    c = c.reshape(-1)[0]\n",
    "    for i in range(siglevelLen):     \n",
    "        cq = cql[i]\n",
    "        cover = c < cq - 0\n",
    "        v = Volumn(WW/sig_h**2/cq)\n",
    "        v = np.log(v)\n",
    "        CI_data[:,1 + 4*i] = np.array([cover, v]).reshape(-1)  # coverage grouped by significance levels\n",
    "    \n",
    "   \n",
    "    \n",
    "    ######################################\n",
    "    #  Modified ALEE - log(n) # Sigma_0 = log_n hard encoded. \n",
    "    Z = np.zeros_like(X)\n",
    "    Sigma0 = np.log(n)*np.eye(d)\n",
    "    for t in range(n):\n",
    "        if t == 0:\n",
    "            S = np.copy(Sigma0)\n",
    "        else:\n",
    "            S = Sigma0 + X[:t,:].T@X[:t,:]\n",
    "        \n",
    "        svd_u, svd_s, svd_v = np.linalg.svd(S, full_matrices=True)\n",
    "        \n",
    "        S_invh = svd_u@np.diag(svd_s**(-0.5))@svd_v\n",
    "\n",
    "        zt = S_invh@X[t,:].reshape(-1,1)\n",
    "        \n",
    "        Z[t,:] = zt.reshape(-1)\n",
    "    \n",
    "    \n",
    "    W = np.zeros_like(Z)\n",
    "    vt = np.eye(d)\n",
    "    for i in range(n):\n",
    "        # zi\n",
    "        z = Z[i,:].reshape(1,-1)\n",
    "        vtt = vt.copy()\n",
    "        term_deno = 1 + z@vtt@z.T\n",
    "        term_deno = term_deno.reshape(-1)[0]\n",
    "        \n",
    "        # update\n",
    "        vt = vtt - vtt@z.T@z@vtt/term_deno\n",
    "        w = np.sqrt(term_deno)*vt@z.T\n",
    "\n",
    "        W[i,:] = w.reshape(-1)\n",
    "        \n",
    "    \n",
    "    ######### design new Zt\n",
    "    kappa = np.log(n)*d\n",
    "    tau = np.sqrt(np.log(n))\n",
    "    Z1 = np.copy(Z)\n",
    "    Vn_inv = np.eye(d) + Z1.T@Z1\n",
    "    evalues, evectors = np.linalg.eig(Vn_inv)\n",
    "    \n",
    "    addn = 0\n",
    "    # construct new Z\n",
    "    for i in range(d):\n",
    "        if evalues[i] < kappa:\n",
    "            dn = int((kappa - evalues[i])*tau)\n",
    "            addn = addn + dn\n",
    "            Z1 = np.concatenate((Z1, np.tile(evectors[:,i], (dn,1))/tau), axis = 0)\n",
    "    \n",
    "    \n",
    "    addW = np.zeros((addn,d))\n",
    "    \n",
    "    for i in range(addn):\n",
    "        z = Z1[i+n,:].reshape(1,-1)\n",
    "        vtt = vt.copy()\n",
    "        term_deno = 1 + z@vtt@z.T\n",
    "        term_deno = term_deno.reshape(-1)[0]\n",
    "        \n",
    "        # update\n",
    "        vt = vtt - vtt@z.T@z@vtt/term_deno\n",
    "        w = np.sqrt(term_deno)*vt@z.T\n",
    "        \n",
    "        addW[i,:] = w.reshape(-1)\n",
    "    \n",
    "    # simulate gaussian random variable\n",
    "    new_error = np.random.normal(0, sig_h, addn).reshape(-1,1)\n",
    "    \n",
    "    # design new estimator\n",
    "    A = W.T@X\n",
    "    alee = np.linalg.inv(A)@(W.T@y.reshape(-1,1) + addW.T@new_error)\n",
    "    OSn = A.T@A\n",
    "    \n",
    "    c = 1/sig_h**2*(alee.reshape(1,-1)- true_theta.reshape(1,-1))@OSn@(alee - true_theta)\n",
    "    c = c.reshape(-1)[0]\n",
    "    for i in range(siglevelLen):\n",
    "        cq = cql[i]\n",
    "        cover = c < cq - 0\n",
    "        \n",
    "        v = Volumn(OSn/sig_h**2/cq)\n",
    "        v = np.log(v)\n",
    "        CI_data[:,2 + 4*i] = np.array([cover, v]).reshape(-1)  # grouped by significance level.\n",
    "\n",
    "    \n",
    "  \n",
    "    \n",
    "    ######################################\n",
    "    # ridge concentration\n",
    "    # set S\n",
    "    S = np.sqrt(d)\n",
    "    rols = np.linalg.inv(X.T@X + clam*np.eye(d))@X.T@y.reshape(-1,1)\n",
    "\n",
    "    # Adding lambdaPar value - clam\n",
    "    Vt = clam * np.eye(d) + Sn\n",
    "\n",
    "    \n",
    "    delta_list = alpha_list.copy()\n",
    "    \n",
    "    c = (rols.reshape(1,-1) - true_theta.reshape(1,-1))@Vt@(rols - true_theta)\n",
    "    c = c.reshape(-1)[0]\n",
    "    \n",
    "    for i in range(siglevelLen):\n",
    "        delta = delta_list[i]\n",
    "        ## Needs to be checked \n",
    "        cq = sig_h*np.sqrt(np.log(np.linalg.det(Vt)/delta**2) - d*np.log(clam)) + np.sqrt(clam)*S \n",
    "        # lambda = 1 and S = |thetastar| \\leq 2   \n",
    "        cover = c < cq**2 - 0\n",
    "        v = Volumn(Vt/cq**2)\n",
    "        v = np.log(v)\n",
    "        CI_data[:,3 + 4*i] = np.array([cover, v]).reshape(-1)\n",
    "    \n",
    "\n",
    "    return CI_data\n",
    "    \n",
    "    \n",
    "    \n",
    "# replication function\n",
    "# N -- number of replications \n",
    "# n -- sample size \n",
    "\n",
    "def ACV_repli(N , n, Actions, wlam, clam,  sampler, alpha_list):\n",
    "    nalpha = np.size(alpha_list)\n",
    "    \n",
    "    E = np.zeros((nalpha, N, 8))\n",
    "    \n",
    "    for i in range(N):\n",
    "        print(i)\n",
    "        output = scaled_estimators(n, Actions, wlam, clam, sampler, alpha_list)\n",
    "        for k in range(nalpha):\n",
    "            E[k,i,:] = output[:,(4*k):(4*k+4)].reshape(1,8)\n",
    "        \n",
    "    return E"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6e0dc3d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# This is for W-decorrelaton lambda stuff. \n",
    "\n",
    "def compute_lam(N, n, sampler, Actions):\n",
    "    \n",
    "    record = np.zeros(N)\n",
    "    for k in range(N):\n",
    "        \n",
    "        X,y = sampler(n,Actions)\n",
    "\n",
    "        evalue, evector = np.linalg.eig(X.T@X)\n",
    "        \n",
    "        record[k] = np.min(evalue)\n",
    "        \n",
    "    return np.percentile(record, 10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "f46dc0a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(517)\n",
    "Actions = get_Actions(30, 20)\n",
    "# first input is the number of actions and second one is dimension.\n",
    "\n",
    "np.random.seed(517)\n",
    "# compute_lam(N, n, sampler, Actions) \n",
    "wlam = compute_lam(1000, 1000, ECB, Actions)/np.log(1000) # this is for W decorrelation "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4a2e7df5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n",
      "20\n",
      "21\n",
      "22\n",
      "23\n",
      "24\n",
      "25\n",
      "26\n",
      "27\n",
      "28\n",
      "29\n",
      "30\n",
      "31\n",
      "32\n",
      "33\n",
      "34\n",
      "35\n",
      "36\n",
      "37\n",
      "38\n",
      "39\n",
      "40\n",
      "41\n",
      "42\n",
      "43\n",
      "44\n",
      "45\n",
      "46\n",
      "47\n",
      "48\n",
      "49\n",
      "50\n",
      "51\n",
      "52\n",
      "53\n",
      "54\n",
      "55\n",
      "56\n",
      "57\n",
      "58\n",
      "59\n",
      "60\n",
      "61\n",
      "62\n",
      "63\n",
      "64\n",
      "65\n",
      "66\n",
      "67\n",
      "68\n",
      "69\n",
      "70\n",
      "71\n",
      "72\n",
      "73\n",
      "74\n",
      "75\n",
      "76\n",
      "77\n",
      "78\n",
      "79\n",
      "80\n",
      "81\n",
      "82\n",
      "83\n",
      "84\n",
      "85\n",
      "86\n",
      "87\n",
      "88\n",
      "89\n",
      "90\n",
      "91\n",
      "92\n",
      "93\n",
      "94\n",
      "95\n",
      "96\n",
      "97\n",
      "98\n",
      "99\n",
      "100\n",
      "101\n",
      "102\n",
      "103\n",
      "104\n",
      "105\n",
      "106\n",
      "107\n",
      "108\n",
      "109\n",
      "110\n",
      "111\n",
      "112\n",
      "113\n",
      "114\n",
      "115\n",
      "116\n",
      "117\n",
      "118\n",
      "119\n",
      "120\n",
      "121\n",
      "122\n",
      "123\n",
      "124\n",
      "125\n",
      "126\n",
      "127\n",
      "128\n",
      "129\n",
      "130\n",
      "131\n",
      "132\n",
      "133\n",
      "134\n",
      "135\n",
      "136\n",
      "137\n",
      "138\n",
      "139\n",
      "140\n",
      "141\n",
      "142\n",
      "143\n",
      "144\n",
      "145\n",
      "146\n",
      "147\n",
      "148\n",
      "149\n",
      "150\n",
      "151\n",
      "152\n",
      "153\n",
      "154\n",
      "155\n",
      "156\n",
      "157\n",
      "158\n",
      "159\n",
      "160\n",
      "161\n",
      "162\n",
      "163\n",
      "164\n",
      "165\n",
      "166\n",
      "167\n",
      "168\n",
      "169\n",
      "170\n",
      "171\n",
      "172\n",
      "173\n",
      "174\n",
      "175\n",
      "176\n",
      "177\n",
      "178\n",
      "179\n",
      "180\n",
      "181\n",
      "182\n",
      "183\n",
      "184\n",
      "185\n",
      "186\n",
      "187\n",
      "188\n",
      "189\n",
      "190\n",
      "191\n",
      "192\n",
      "193\n",
      "194\n",
      "195\n",
      "196\n",
      "197\n",
      "198\n",
      "199\n",
      "200\n",
      "201\n",
      "202\n",
      "203\n",
      "204\n",
      "205\n",
      "206\n",
      "207\n",
      "208\n",
      "209\n",
      "210\n",
      "211\n",
      "212\n",
      "213\n",
      "214\n",
      "215\n",
      "216\n",
      "217\n",
      "218\n",
      "219\n",
      "220\n",
      "221\n",
      "222\n",
      "223\n",
      "224\n",
      "225\n",
      "226\n",
      "227\n",
      "228\n",
      "229\n",
      "230\n",
      "231\n",
      "232\n",
      "233\n",
      "234\n",
      "235\n",
      "236\n",
      "237\n",
      "238\n",
      "239\n",
      "240\n",
      "241\n",
      "242\n",
      "243\n",
      "244\n",
      "245\n",
      "246\n",
      "247\n",
      "248\n",
      "249\n",
      "250\n",
      "251\n",
      "252\n",
      "253\n",
      "254\n",
      "255\n",
      "256\n",
      "257\n",
      "258\n",
      "259\n",
      "260\n",
      "261\n",
      "262\n",
      "263\n",
      "264\n",
      "265\n",
      "266\n",
      "267\n",
      "268\n",
      "269\n",
      "270\n",
      "271\n",
      "272\n",
      "273\n",
      "274\n",
      "275\n",
      "276\n",
      "277\n",
      "278\n",
      "279\n",
      "280\n",
      "281\n",
      "282\n",
      "283\n",
      "284\n",
      "285\n",
      "286\n",
      "287\n",
      "288\n",
      "289\n",
      "290\n",
      "291\n",
      "292\n",
      "293\n",
      "294\n",
      "295\n",
      "296\n",
      "297\n",
      "298\n",
      "299\n",
      "300\n",
      "301\n",
      "302\n",
      "303\n",
      "304\n",
      "305\n",
      "306\n",
      "307\n",
      "308\n",
      "309\n",
      "310\n",
      "311\n",
      "312\n",
      "313\n",
      "314\n",
      "315\n",
      "316\n",
      "317\n",
      "318\n",
      "319\n",
      "320\n",
      "321\n",
      "322\n",
      "323\n",
      "324\n",
      "325\n",
      "326\n",
      "327\n",
      "328\n",
      "329\n",
      "330\n",
      "331\n",
      "332\n",
      "333\n",
      "334\n",
      "335\n",
      "336\n",
      "337\n",
      "338\n",
      "339\n",
      "340\n",
      "341\n",
      "342\n",
      "343\n",
      "344\n",
      "345\n",
      "346\n",
      "347\n",
      "348\n",
      "349\n",
      "350\n",
      "351\n",
      "352\n",
      "353\n",
      "354\n",
      "355\n",
      "356\n",
      "357\n",
      "358\n",
      "359\n",
      "360\n",
      "361\n",
      "362\n",
      "363\n",
      "364\n",
      "365\n",
      "366\n",
      "367\n",
      "368\n",
      "369\n",
      "370\n",
      "371\n",
      "372\n",
      "373\n",
      "374\n",
      "375\n",
      "376\n",
      "377\n",
      "378\n",
      "379\n",
      "380\n",
      "381\n",
      "382\n",
      "383\n",
      "384\n",
      "385\n",
      "386\n",
      "387\n",
      "388\n",
      "389\n",
      "390\n",
      "391\n",
      "392\n",
      "393\n",
      "394\n",
      "395\n",
      "396\n",
      "397\n",
      "398\n",
      "399\n",
      "400\n",
      "401\n",
      "402\n",
      "403\n",
      "404\n",
      "405\n",
      "406\n",
      "407\n",
      "408\n",
      "409\n",
      "410\n",
      "411\n",
      "412\n",
      "413\n",
      "414\n",
      "415\n",
      "416\n",
      "417\n",
      "418\n",
      "419\n",
      "420\n",
      "421\n",
      "422\n",
      "423\n",
      "424\n",
      "425\n",
      "426\n",
      "427\n",
      "428\n",
      "429\n",
      "430\n",
      "431\n",
      "432\n",
      "433\n",
      "434\n",
      "435\n",
      "436\n",
      "437\n",
      "438\n",
      "439\n",
      "440\n",
      "441\n",
      "442\n",
      "443\n",
      "444\n",
      "445\n",
      "446\n",
      "447\n",
      "448\n",
      "449\n",
      "450\n",
      "451\n",
      "452\n",
      "453\n",
      "454\n",
      "455\n",
      "456\n",
      "457\n",
      "458\n",
      "459\n",
      "460\n",
      "461\n",
      "462\n",
      "463\n",
      "464\n",
      "465\n",
      "466\n",
      "467\n",
      "468\n",
      "469\n",
      "470\n",
      "471\n",
      "472\n",
      "473\n",
      "474\n",
      "475\n",
      "476\n",
      "477\n",
      "478\n",
      "479\n",
      "480\n",
      "481\n",
      "482\n",
      "483\n",
      "484\n",
      "485\n",
      "486\n",
      "487\n",
      "488\n",
      "489\n",
      "490\n",
      "491\n",
      "492\n",
      "493\n",
      "494\n",
      "495\n",
      "496\n",
      "497\n",
      "498\n",
      "499\n",
      "500\n",
      "501\n",
      "502\n",
      "503\n",
      "504\n",
      "505\n",
      "506\n",
      "507\n",
      "508\n",
      "509\n",
      "510\n",
      "511\n",
      "512\n",
      "513\n",
      "514\n",
      "515\n",
      "516\n",
      "517\n",
      "518\n",
      "519\n",
      "520\n",
      "521\n",
      "522\n",
      "523\n",
      "524\n",
      "525\n",
      "526\n",
      "527\n",
      "528\n",
      "529\n",
      "530\n",
      "531\n",
      "532\n",
      "533\n",
      "534\n",
      "535\n",
      "536\n",
      "537\n",
      "538\n",
      "539\n",
      "540\n",
      "541\n",
      "542\n",
      "543\n",
      "544\n",
      "545\n",
      "546\n",
      "547\n",
      "548\n",
      "549\n",
      "550\n",
      "551\n",
      "552\n",
      "553\n",
      "554\n",
      "555\n",
      "556\n",
      "557\n",
      "558\n",
      "559\n",
      "560\n",
      "561\n",
      "562\n",
      "563\n",
      "564\n",
      "565\n",
      "566\n",
      "567\n",
      "568\n",
      "569\n",
      "570\n",
      "571\n",
      "572\n",
      "573\n",
      "574\n",
      "575\n",
      "576\n",
      "577\n",
      "578\n",
      "579\n",
      "580\n",
      "581\n",
      "582\n",
      "583\n",
      "584\n",
      "585\n",
      "586\n",
      "587\n",
      "588\n",
      "589\n",
      "590\n",
      "591\n",
      "592\n",
      "593\n",
      "594\n",
      "595\n",
      "596\n",
      "597\n",
      "598\n",
      "599\n",
      "600\n",
      "601\n",
      "602\n",
      "603\n",
      "604\n",
      "605\n",
      "606\n",
      "607\n",
      "608\n",
      "609\n",
      "610\n",
      "611\n",
      "612\n",
      "613\n",
      "614\n",
      "615\n",
      "616\n",
      "617\n",
      "618\n",
      "619\n",
      "620\n",
      "621\n",
      "622\n",
      "623\n",
      "624\n",
      "625\n",
      "626\n",
      "627\n",
      "628\n",
      "629\n",
      "630\n",
      "631\n",
      "632\n",
      "633\n",
      "634\n",
      "635\n",
      "636\n",
      "637\n",
      "638\n",
      "639\n",
      "640\n",
      "641\n",
      "642\n",
      "643\n",
      "644\n",
      "645\n",
      "646\n",
      "647\n",
      "648\n",
      "649\n",
      "650\n",
      "651\n",
      "652\n",
      "653\n",
      "654\n",
      "655\n",
      "656\n",
      "657\n",
      "658\n",
      "659\n",
      "660\n",
      "661\n",
      "662\n",
      "663\n",
      "664\n",
      "665\n",
      "666\n",
      "667\n",
      "668\n",
      "669\n",
      "670\n",
      "671\n",
      "672\n",
      "673\n",
      "674\n",
      "675\n",
      "676\n",
      "677\n",
      "678\n",
      "679\n",
      "680\n",
      "681\n",
      "682\n",
      "683\n",
      "684\n",
      "685\n",
      "686\n",
      "687\n",
      "688\n",
      "689\n",
      "690\n",
      "691\n",
      "692\n",
      "693\n",
      "694\n",
      "695\n",
      "696\n",
      "697\n",
      "698\n",
      "699\n",
      "700\n",
      "701\n",
      "702\n",
      "703\n",
      "704\n",
      "705\n",
      "706\n",
      "707\n",
      "708\n",
      "709\n",
      "710\n",
      "711\n",
      "712\n",
      "713\n",
      "714\n",
      "715\n",
      "716\n",
      "717\n",
      "718\n",
      "719\n",
      "720\n",
      "721\n",
      "722\n",
      "723\n",
      "724\n",
      "725\n",
      "726\n",
      "727\n",
      "728\n",
      "729\n",
      "730\n",
      "731\n",
      "732\n",
      "733\n",
      "734\n",
      "735\n",
      "736\n",
      "737\n",
      "738\n",
      "739\n",
      "740\n",
      "741\n",
      "742\n",
      "743\n",
      "744\n",
      "745\n",
      "746\n",
      "747\n",
      "748\n",
      "749\n",
      "750\n",
      "751\n",
      "752\n",
      "753\n",
      "754\n",
      "755\n",
      "756\n",
      "757\n",
      "758\n",
      "759\n",
      "760\n",
      "761\n",
      "762\n",
      "763\n",
      "764\n",
      "765\n",
      "766\n",
      "767\n",
      "768\n",
      "769\n",
      "770\n",
      "771\n",
      "772\n",
      "773\n",
      "774\n",
      "775\n",
      "776\n",
      "777\n",
      "778\n",
      "779\n",
      "780\n",
      "781\n",
      "782\n",
      "783\n",
      "784\n",
      "785\n",
      "786\n",
      "787\n",
      "788\n",
      "789\n",
      "790\n",
      "791\n",
      "792\n",
      "793\n",
      "794\n",
      "795\n",
      "796\n",
      "797\n",
      "798\n",
      "799\n",
      "800\n",
      "801\n",
      "802\n",
      "803\n",
      "804\n",
      "805\n",
      "806\n",
      "807\n",
      "808\n",
      "809\n",
      "810\n",
      "811\n",
      "812\n",
      "813\n",
      "814\n",
      "815\n",
      "816\n",
      "817\n",
      "818\n",
      "819\n",
      "820\n",
      "821\n",
      "822\n",
      "823\n",
      "824\n",
      "825\n",
      "826\n",
      "827\n",
      "828\n",
      "829\n",
      "830\n",
      "831\n",
      "832\n",
      "833\n",
      "834\n",
      "835\n",
      "836\n",
      "837\n",
      "838\n",
      "839\n",
      "840\n",
      "841\n",
      "842\n",
      "843\n",
      "844\n",
      "845\n",
      "846\n",
      "847\n",
      "848\n",
      "849\n",
      "850\n",
      "851\n",
      "852\n",
      "853\n",
      "854\n",
      "855\n",
      "856\n",
      "857\n",
      "858\n",
      "859\n",
      "860\n",
      "861\n",
      "862\n",
      "863\n",
      "864\n",
      "865\n",
      "866\n",
      "867\n",
      "868\n",
      "869\n",
      "870\n",
      "871\n",
      "872\n",
      "873\n",
      "874\n",
      "875\n",
      "876\n",
      "877\n",
      "878\n",
      "879\n",
      "880\n",
      "881\n",
      "882\n",
      "883\n",
      "884\n",
      "885\n",
      "886\n",
      "887\n",
      "888\n",
      "889\n",
      "890\n",
      "891\n",
      "892\n",
      "893\n",
      "894\n",
      "895\n",
      "896\n",
      "897\n",
      "898\n",
      "899\n",
      "900\n",
      "901\n",
      "902\n",
      "903\n",
      "904\n",
      "905\n",
      "906\n",
      "907\n",
      "908\n",
      "909\n",
      "910\n",
      "911\n",
      "912\n",
      "913\n",
      "914\n",
      "915\n",
      "916\n",
      "917\n",
      "918\n",
      "919\n",
      "920\n",
      "921\n",
      "922\n",
      "923\n",
      "924\n",
      "925\n",
      "926\n",
      "927\n",
      "928\n",
      "929\n",
      "930\n",
      "931\n",
      "932\n",
      "933\n",
      "934\n",
      "935\n",
      "936\n",
      "937\n",
      "938\n",
      "939\n",
      "940\n",
      "941\n",
      "942\n",
      "943\n",
      "944\n",
      "945\n",
      "946\n",
      "947\n",
      "948\n",
      "949\n",
      "950\n",
      "951\n",
      "952\n",
      "953\n",
      "954\n",
      "955\n",
      "956\n",
      "957\n",
      "958\n",
      "959\n",
      "960\n",
      "961\n",
      "962\n",
      "963\n",
      "964\n",
      "965\n",
      "966\n",
      "967\n",
      "968\n",
      "969\n",
      "970\n",
      "971\n",
      "972\n",
      "973\n",
      "974\n",
      "975\n",
      "976\n",
      "977\n",
      "978\n",
      "979\n",
      "980\n",
      "981\n",
      "982\n",
      "983\n",
      "984\n",
      "985\n",
      "986\n",
      "987\n",
      "988\n",
      "989\n",
      "990\n",
      "991\n",
      "992\n",
      "993\n",
      "994\n",
      "995\n",
      "996\n",
      "997\n",
      "998\n",
      "999\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(517)\n",
    "Actions = get_Actions(30, 20)\n",
    "\n",
    "np.random.seed(517)\n",
    "alpha_list = np.array([0.2, 0.15,0.1])\n",
    "E = ACV_repli(1000, 1000, Actions, wlam, clam = 0.01, sampler = ECB, alpha_list=  alpha_list )"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8be6ca77",
   "metadata": {},
   "source": [
    "# Confidence level first one"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d996171b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>ols</th>\n",
       "      <th>W</th>\n",
       "      <th>ALEE-logn</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.776</td>\n",
       "      <td>0.777</td>\n",
       "      <td>0.805</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-2.079</td>\n",
       "      <td>25.727</td>\n",
       "      <td>6.541</td>\n",
       "      <td>17.374</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     ols       W  ALEE-logn  Concentration\n",
       "0  0.776   0.777      0.805          1.000\n",
       "1 -2.079  25.727      6.541         17.374"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.mean(E[0,:,:], axis = 0).reshape(2,4), columns = ['ols','W', 'ALEE-logn', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "e9a9ea3c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>ols</th>\n",
       "      <th>W</th>\n",
       "      <th>ALEE-logn</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.417</td>\n",
       "      <td>0.416</td>\n",
       "      <td>0.396</td>\n",
       "      <td>0.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.525</td>\n",
       "      <td>0.518</td>\n",
       "      <td>0.528</td>\n",
       "      <td>0.506</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     ols      W  ALEE-logn  Concentration\n",
       "0  0.417  0.416      0.396          0.000\n",
       "1  0.525  0.518      0.528          0.506"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.std(E[0,:,:], axis = 0).reshape(2,4), columns = ['ols','W', 'ALEE-logn', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2700ec0c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f2d316fa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "2c6f2cac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>OLS</th>\n",
       "      <th>W</th>\n",
       "      <th>ALEE-logn</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.830</td>\n",
       "      <td>0.829</td>\n",
       "      <td>0.861</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-1.513</td>\n",
       "      <td>26.294</td>\n",
       "      <td>7.108</td>\n",
       "      <td>17.408</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     OLS       W  ALEE-logn  Concentration\n",
       "0  0.830   0.829      0.861          1.000\n",
       "1 -1.513  26.294      7.108         17.408"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.mean(E[1,:,:], axis = 0).reshape(2,4), columns = ['OLS','W', 'ALEE-logn', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "2f7ca64f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>OLS</th>\n",
       "      <th>W</th>\n",
       "      <th>ALEE-logn</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.376</td>\n",
       "      <td>0.377</td>\n",
       "      <td>0.346</td>\n",
       "      <td>0.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.525</td>\n",
       "      <td>0.518</td>\n",
       "      <td>0.528</td>\n",
       "      <td>0.506</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     OLS      W  ALEE-logn  Concentration\n",
       "0  0.376  0.377      0.346          0.000\n",
       "1  0.525  0.518      0.528          0.506"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.std(E[1,:,:], axis = 0).reshape(2,4), columns = ['OLS','W', 'ALEE-logn', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "873709ea",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8abeb72",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "be65469a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>ols</th>\n",
       "      <th>W</th>\n",
       "      <th>ALEE-logn</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.881</td>\n",
       "      <td>0.870</td>\n",
       "      <td>0.910</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-0.815</td>\n",
       "      <td>26.992</td>\n",
       "      <td>7.806</td>\n",
       "      <td>17.455</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     ols       W  ALEE-logn  Concentration\n",
       "0  0.881   0.870      0.910          1.000\n",
       "1 -0.815  26.992      7.806         17.455"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.mean(E[2,:,:], axis = 0).reshape(2,4), columns = ['ols','W', 'ALEE-logn', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "812719ef",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>OLS</th>\n",
       "      <th>W</th>\n",
       "      <th>ALEE-logn</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.324</td>\n",
       "      <td>0.336</td>\n",
       "      <td>0.286</td>\n",
       "      <td>0.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.525</td>\n",
       "      <td>0.518</td>\n",
       "      <td>0.528</td>\n",
       "      <td>0.506</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     OLS      W  ALEE-logn  Concentration\n",
       "0  0.324  0.336      0.286          0.000\n",
       "1  0.525  0.518      0.528          0.506"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.std(E[2,:,:], axis = 0).reshape(2,4), columns = ['OLS','W', 'ALEE-logn', 'Concentration'])\n",
    "round(df,3)"
   ]
  }
 ],
 "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
}
