{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "9293928f",
   "metadata": {},
   "source": [
    "# Stochastic regression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4aeaa1c2",
   "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": "dc14f7af",
   "metadata": {},
   "outputs": [],
   "source": [
    "# define reward function\n",
    "def get_noise():\n",
    "    return  np.random.binomial(1,0.5,1)[0] - 0.5\n",
    "\n",
    "def get_unitv():\n",
    "    # generate unit vector in sphere\n",
    "    x = np.random.normal(0,1,2)\n",
    "    return x/np.linalg.norm(x)\n",
    "\n",
    "# stochastic regression\n",
    "def stoc(n):\n",
    "    # y = 0.3 + 0.3 x + eps\n",
    "    x = np.zeros(n)\n",
    "    eps = np.random.normal(0,1,n)\n",
    "    # x_{n+1} = mean(x_{1:n}) + np.mean(eps_{1:n})\n",
    "    for i in range(n):\n",
    "        if i>0:\n",
    "            c = 1\n",
    "            x[i] = np.mean(x[:i]) + c*np.mean(eps[:i])\n",
    "    y = 0.3 + x*0.3 + eps \n",
    "    \n",
    "    X = np.concatenate((np.ones((n,1)), x.reshape(-1,1)), axis = 1)\n",
    "    return  X,y"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0c9325f8",
   "metadata": {},
   "source": [
    "## $\\Sigma_0 = e^2 \\log(n)$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2b8795d2",
   "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",
    "def scaled_estimators(n, lam, sampler):\n",
    "    \n",
    "    # consider confidence level 0.8, 0.85, 0.9\n",
    "    cql = chi2.ppf([0.8, 0.85, 0.9], 2)\n",
    "    true_theta = np.array([0.3, 0.3]).reshape(-1,1)\n",
    "    CI_data = np.zeros((2,15))\n",
    "    \n",
    "    X,y = sampler(n)\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",
    "    for i in range(3):\n",
    "        cq = cql[i]\n",
    "        cover = c < cq - 0\n",
    "        r = cq**1.5*sig_h**3\n",
    "        v = Volumn(Sn)*r\n",
    "        v = np.log(v)\n",
    "        CI_data[:,0 + 5*i] = np.array([cover, v]).reshape(-1)\n",
    "    \n",
    "    #######################################\n",
    "    # W-decorrelation\n",
    "    W_lambdas = np.ones(n)*lam\n",
    "    # Latest parameter estimate vector\n",
    "    wols = M.coef_.copy()\n",
    "    # Latest w_t vector\n",
    "    w = np.zeros((2,1))\n",
    "    # Latest matrix W_tX_t = w_1 x_1^T + ... + w_t x_t^T\n",
    "    WX = np.zeros((2,2))\n",
    "    # Latest vector of marginal variances reward_vars * (w_1**2 + ... + w_t**2)\n",
    "    W = np.zeros_like(X)\n",
    "    for t in range(n):\n",
    "        # Update w_t = (1/(norm{x_t}^2+lambda_t)) (x_t - W_{t-1} X_{t-1} x_t)\n",
    "        w = (np.eye(2) - WX)@X[t,:].reshape(-1,1) \n",
    "        w = w/(np.sum(X[t,:]**2) + W_lambdas[t])\n",
    "        W[t, :] = w.reshape(-1)\n",
    "        # Update beta_t = beta_{t-1} + w_t (y_t - <beta_OLS, x_t>)\n",
    "        wols += w.reshape(-1) * (y[t] - np.sum(X[t,:]*coeff.reshape(-1)) ) ###\n",
    "        # Update W_tX_t = W_{t-1}X_{t-1} + w_t x_t^T \n",
    "        WX = WX + w@X[t,:].reshape(1,-1)\n",
    "        \n",
    "    WW = np.linalg.inv(W.T@W)\n",
    "    r = cq**1.5*sig_h**3\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(3):\n",
    "        cq = cql[i]\n",
    "        cover = c < cq - 0\n",
    "        r = cq**1.5*sig_h**3\n",
    "        v = Volumn(WW)*r\n",
    "        v = np.log(v)\n",
    "        CI_data[:,1 + 5*i] = np.array([cover, v]).reshape(-1)\n",
    "    \n",
    "    \n",
    "    \n",
    "    ######################################\n",
    "    #  Modified ALEE - log(n)\n",
    "    Z = np.zeros_like(X)\n",
    "    for t in range(n):\n",
    "        if t == 0:\n",
    "            S = np.log(n)*np.eye(2)\n",
    "        elif t == 1:\n",
    "            Xsub = X[:t,:].reshape(-1,2)\n",
    "            S = np.log(n)*np.eye(2) + Xsub.T@Xsub\n",
    "        else:\n",
    "            Xsub = X[:t,:]\n",
    "            S = np.log(n)*np.eye(2) + Xsub.T@Xsub\n",
    "        \n",
    "        S_invh = scipy.linalg.sqrtm(np.linalg.inv(S))\n",
    "        \n",
    "        zt = S_invh@X[t,:].reshape(-1,1)\n",
    "        Z[t,:] = zt.reshape(-1)\n",
    "    \n",
    "    \n",
    "    W = np.zeros_like(Z)\n",
    "    for i in range(n):\n",
    "        if i==0:\n",
    "            z = Z[0,:].reshape(1,-1)\n",
    "            vtt = np.eye(2)\n",
    "            vt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "        elif i == 1:\n",
    "            z = Z[:(i+1),:]\n",
    "            vtt = vt\n",
    "            vt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "        else:\n",
    "            z = Z[:(i+1),:]\n",
    "            vt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "            z = Z[:i,:]\n",
    "            vtt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "        \n",
    "        w = vt@Z[i,:].reshape(-1,1)\n",
    "        \n",
    "        w_factor = np.sqrt(1 + Z[i,:].reshape(1,-1)@vtt@Z[i,:].reshape(-1,1))\n",
    "        w = w_factor.reshape(-1)[0]*w\n",
    "        \n",
    "        W[i,:] = w.reshape(-1)\n",
    "        \n",
    "    \n",
    "    ######### design new Zt\n",
    "    kappa = np.log(n)\n",
    "    tau = np.exp(1)*np.sqrt(np.log(n))\n",
    "    Z1 = np.copy(Z)\n",
    "    Vn_inv = np.eye(2) + Z1.T@Z1\n",
    "    evalues, evectors = np.linalg.eig(Vn_inv)\n",
    "    \n",
    "    addn = 0\n",
    "    # construct new Z\n",
    "    for i in range(2):\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,2))\n",
    "    \n",
    "    for i in range(addn):\n",
    "    \n",
    "        z = Z1[:(i+n+1),:]\n",
    "        vt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "        z = Z1[:(i+n),:]\n",
    "        vtt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "        w = vt@Z1[i,:].reshape(-1,1)\n",
    "        w_factor = np.sqrt(1 + Z1[i,:].reshape(1,-1)@vtt@Z1[i,:].reshape(-1,1))\n",
    "        w = w_factor.reshape(-1)[0]*w\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",
    "    \n",
    "    OSn = A.T@A\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(3):\n",
    "        cq = cql[i]\n",
    "        cover = c < cq - 0\n",
    "        r = cq**1.5*sig_h**3\n",
    "        v = Volumn(OSn)*r\n",
    "        v = np.log(v)\n",
    "        CI_data[:,2 + 5*i] = np.array([cover, v]).reshape(-1)\n",
    "\n",
    "    \n",
    "    \n",
    "    ######################################\n",
    "    # ALEE - n**0.5\n",
    "    \n",
    "    Z = np.zeros_like(X)\n",
    "    for t in range(n):\n",
    "        if t == 0:\n",
    "            S = np.exp(2)*np.eye(2)*n**0.5\n",
    "        elif t == 1:\n",
    "            Xsub = X[:t,:].reshape(-1,2)\n",
    "            S = np.exp(2)*np.eye(2)*n**0.5 + Xsub.T@Xsub\n",
    "        else:\n",
    "            Xsub = X[:t,:]\n",
    "            S = np.exp(2)*np.eye(2)*n**0.5 + Xsub.T@Xsub\n",
    "        \n",
    "        S_invh = scipy.linalg.sqrtm(np.linalg.inv(S))\n",
    "        \n",
    "        zt = S_invh@X[t,:].reshape(-1,1)\n",
    "        Z[t,:] = zt.reshape(-1)\n",
    "    \n",
    "    \n",
    "    W = np.zeros_like(Z)\n",
    "    for i in range(n):\n",
    "        if i==0:\n",
    "            z = Z[0,:].reshape(1,-1)\n",
    "            vtt = np.eye(2)\n",
    "            vt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "        elif i == 1:\n",
    "            z = Z[:(i+1),:]\n",
    "            vtt = vt\n",
    "            vt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "        else:\n",
    "            z = Z[:(i+1),:]\n",
    "            vt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "            z = Z[:i,:]\n",
    "            vtt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "        \n",
    "        w = vt@Z[i,:].reshape(-1,1)\n",
    "        \n",
    "        w_factor = np.sqrt(1 + Z[i,:].reshape(1,-1)@vtt@Z[i,:].reshape(-1,1))\n",
    "        w = w_factor.reshape(-1)[0]*w\n",
    "        \n",
    "        W[i,:] = w.reshape(-1)\n",
    "        \n",
    "    \n",
    "    ######### design new Zt\n",
    "    kappa = np.log(n)\n",
    "    tau = np.exp(1)*n**0.25\n",
    "    Z1 = np.copy(Z)\n",
    "    Vn_inv = np.eye(2) + Z1.T@Z1\n",
    "    evalues, evectors = np.linalg.eig(Vn_inv)\n",
    "    \n",
    "    addn = 0\n",
    "    # construct new Z\n",
    "    for i in range(2):\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,2))\n",
    "    \n",
    "    for i in range(addn):\n",
    "    \n",
    "        z = Z1[:(i+n+1),:]\n",
    "        vt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "        z = Z1[:(i+n),:]\n",
    "        vtt = np.linalg.inv(np.eye(2) + z.T@z)\n",
    "        w = vt@Z1[i,:].reshape(-1,1)\n",
    "        w_factor = np.sqrt(1 + Z1[i,:].reshape(1,-1)@vtt@Z1[i,:].reshape(-1,1))\n",
    "        w = w_factor.reshape(-1)[0]*w\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",
    "    \n",
    "    OSn = A.T@A\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(3):\n",
    "        cq = cql[i]\n",
    "        cover = c < cq - 0\n",
    "        r = cq**1.5*sig_h**3\n",
    "        v = Volumn(OSn)*r\n",
    "        v = np.log(v)\n",
    "        CI_data[:,3 + 5*i] = np.array([cover, v]).reshape(-1)\n",
    "\n",
    "    \n",
    "    \n",
    "    \n",
    "    \n",
    "    ######################################\n",
    "    # ridge concentration\n",
    "    \n",
    "    rols = np.linalg.inv(X.T@X + np.eye(2))@X.T@y.reshape(-1,1)\n",
    "    # lambda = 1\n",
    "    Vt = np.eye(2) + Sn\n",
    "    delta_list = [0.2, 0.15, 0.1]\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(3):\n",
    "        delta = delta_list[i]\n",
    "        cq = sig_h*np.sqrt(np.log(np.linalg.det(Vt)/delta**2)) + 1\n",
    "        cover = c < cq**2 - 0\n",
    "        v = Volumn(Vt)*cq**3\n",
    "        v = np.log(v)\n",
    "        CI_data[:,4 + 5*i] = np.array([cover, v]).reshape(-1)\n",
    "    \n",
    "\n",
    "    return CI_data\n",
    "    \n",
    "    \n",
    "    \n",
    "#   replication function\n",
    "def ACV_repli(N , n, lam,  sampler):\n",
    "    E1 = np.zeros((N, 10))\n",
    "    E2 = np.zeros((N, 10))\n",
    "    E3 = np.zeros((N, 10))\n",
    "    \n",
    "    for i in range(N):\n",
    "        output = scaled_estimators(n, lam, sampler)\n",
    "        E1[i,:] =  output[:,:5].reshape(1,10)\n",
    "        E2[i,:] =  output[:,5:10].reshape(1,10)\n",
    "        E3[i,:] =  output[:,10:15].reshape(1,10)\n",
    "        \n",
    "    return (E1,E2,E3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a93e7676",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_lam(N, n, sampler):\n",
    "    \n",
    "    record = np.zeros(N)\n",
    "    for k in range(N):\n",
    "        \n",
    "        X,y = sampler(n)\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": "cac2ca7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(517)\n",
    "lam = compute_lam(1000, 1000, stoc)/np.log(1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "dc36469d",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(517)\n",
    "E1,E2,E3 = ACV_repli(1000, 1000, lam, stoc)\n",
    "\n",
    "\n",
    "np.save('E1', E1)\n",
    "np.save('E2', E2)\n",
    "np.save('E3', E3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6aa3d108",
   "metadata": {},
   "source": [
    "# Confidence level 0.8"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9aa9d1d4",
   "metadata": {},
   "source": [
    "## First row represents coverage ; second row represents average log (Volume)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "6a5b921f",
   "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>ALEE-n</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.000</td>\n",
       "      <td>0.185</td>\n",
       "      <td>0.930</td>\n",
       "      <td>0.964</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-2.555</td>\n",
       "      <td>0.812</td>\n",
       "      <td>-0.876</td>\n",
       "      <td>0.116</td>\n",
       "      <td>0.017</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     ols      W  ALEE-logn  ALEE-n  Concentration\n",
       "0  0.000  0.185      0.930   0.964          1.000\n",
       "1 -2.555  0.812     -0.876   0.116          0.017"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.mean(E1, axis = 0).reshape(2,5), columns = ['ols','W', 'ALEE-logn','ALEE-n', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "479a2bd4",
   "metadata": {},
   "source": [
    "## Standard errors for empirical coverage and logarithm of volume"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "80ff5527",
   "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>ALEE-n</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.00</td>\n",
       "      <td>0.388</td>\n",
       "      <td>0.255</td>\n",
       "      <td>0.186</td>\n",
       "      <td>0.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.32</td>\n",
       "      <td>0.167</td>\n",
       "      <td>0.431</td>\n",
       "      <td>0.501</td>\n",
       "      <td>0.244</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    ols      W  ALEE-logn  ALEE-n  Concentration\n",
       "0  0.00  0.388      0.255   0.186          0.000\n",
       "1  0.32  0.167      0.431   0.501          0.244"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.std(E1, axis = 0).reshape(2,5), columns = ['ols','W', 'ALEE-logn','ALEE-n', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c3e00f02",
   "metadata": {},
   "source": [
    "# Confidence level 0.85"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "15f21ca4",
   "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>ALEE-n</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.000</td>\n",
       "      <td>0.222</td>\n",
       "      <td>0.95</td>\n",
       "      <td>0.972</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-2.308</td>\n",
       "      <td>1.059</td>\n",
       "      <td>-0.63</td>\n",
       "      <td>0.363</td>\n",
       "      <td>0.071</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     ols      W  ALEE-logn  ALEE-n  Concentration\n",
       "0  0.000  0.222       0.95   0.972          1.000\n",
       "1 -2.308  1.059      -0.63   0.363          0.071"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.mean(E2, axis = 0).reshape(2,5), columns = ['ols','W', 'ALEE-logn','ALEE-n', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c65e83d6",
   "metadata": {},
   "source": [
    "## Standard errors for empirical coverage and logarithm of volume"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "8d2f15f4",
   "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>ALEE-n</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.00</td>\n",
       "      <td>0.416</td>\n",
       "      <td>0.218</td>\n",
       "      <td>0.165</td>\n",
       "      <td>0.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.32</td>\n",
       "      <td>0.167</td>\n",
       "      <td>0.431</td>\n",
       "      <td>0.501</td>\n",
       "      <td>0.246</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    ols      W  ALEE-logn  ALEE-n  Concentration\n",
       "0  0.00  0.416      0.218   0.165          0.000\n",
       "1  0.32  0.167      0.431   0.501          0.246"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.std(E2, axis = 0).reshape(2,5), columns = ['ols','W', 'ALEE-logn','ALEE-n', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c1e253a3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "bd10612c",
   "metadata": {},
   "source": [
    "# Confidence level 0.9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "f056380b",
   "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>ALEE-n</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.001</td>\n",
       "      <td>0.279</td>\n",
       "      <td>0.974</td>\n",
       "      <td>0.989</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-2.017</td>\n",
       "      <td>1.350</td>\n",
       "      <td>-0.339</td>\n",
       "      <td>0.653</td>\n",
       "      <td>0.144</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     ols      W  ALEE-logn  ALEE-n  Concentration\n",
       "0  0.001  0.279      0.974   0.989          1.000\n",
       "1 -2.017  1.350     -0.339   0.653          0.144"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.mean(E3, axis = 0).reshape(2,5), columns = ['ols','W', 'ALEE-logn','ALEE-n', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7b9b6adc",
   "metadata": {},
   "source": [
    "## Standard errors for empirical coverage and logarithm of volume"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "855f8281",
   "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>ALEE-n</th>\n",
       "      <th>Concentration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.032</td>\n",
       "      <td>0.449</td>\n",
       "      <td>0.159</td>\n",
       "      <td>0.104</td>\n",
       "      <td>0.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.320</td>\n",
       "      <td>0.167</td>\n",
       "      <td>0.431</td>\n",
       "      <td>0.501</td>\n",
       "      <td>0.249</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     ols      W  ALEE-logn  ALEE-n  Concentration\n",
       "0  0.032  0.449      0.159   0.104          0.000\n",
       "1  0.320  0.167      0.431   0.501          0.249"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(np.std(E3, axis = 0).reshape(2,5), columns = ['ols','W', 'ALEE-logn','ALEE-n', 'Concentration'])\n",
    "round(df,3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75a5607c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43488ace",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1dcbcb4c",
   "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
}
