{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 118,
   "id": "6808194c-d5be-46aa-8744-165acb79ddbd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm\n",
    "from math import sqrt\n",
    "from scipy.integrate import quad\n",
    "from scipy.stats import norm\n",
    "from scipy import stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 208,
   "id": "b5984af0-bef7-463a-9b0c-1d6087c4631c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# get the number of simulations based on the \n",
    "\n",
    "def ETC(T, mu1, mu2, m=1):\n",
    "    #Y11 = np.random.normal(mu1, sigma1, int(T/2))\n",
    "    #Y12 = np.random.normal(mu2, sigma2, int(T/2))\n",
    "\n",
    "    Y11 = np.random.binomial(n=1, p = mu1, size = int(T/2))\n",
    "    Y12 = np.random.binomial(n=1, p = mu2, size = int(T/2))\n",
    "\n",
    "    N_2 = T/2\n",
    "    \n",
    "    if np.mean(Y11) > (np.mean(Y12)):\n",
    "        #Y2 = np.random.normal(mu1, sigma1, m * T)\n",
    "        Y2 = np.random.binomial(n=1, p = mu1, size = int(m*T))\n",
    "        theta_hat, eta_hat = np.mean(np.concatenate([Y11, Y2])), np.mean(Y12)\n",
    "        var1, var2 = np.var(np.concatenate([Y11, Y2])), np.var(Y12)\n",
    "        \n",
    "    else:\n",
    "        #Y2 = np.random.normal(mu2, sigma2, m * T)\n",
    "        Y2 = np.random.binomial(n=1, p = mu2, size = int(m*T))\n",
    "        #theta_hat, eta_hat = np.mean(Y11), np.mean(eta_obs)\n",
    "        theta_hat, eta_hat = np.mean(Y11), np.mean(np.concatenate([Y12, Y2]))\n",
    "        var1, var2 = np.var(Y11), np.var(np.concatenate([Y12, Y2]))\n",
    "        N_2 = N_2 + m*T\n",
    "        \n",
    "\n",
    "    return theta_hat, eta_hat + np.max([np.log(np.log(N_2)) * np.sqrt(1/N_2), 0]), eta_hat, var1, var2\n",
    "\n",
    "def ETC_sim(T, mu1, eta_hat, var1, var2, m=1):\n",
    "    #Y11 = np.random.normal(mu1, np.sqrt(var1), int(T/2))\n",
    "    #Y12 = np.random.normal(mu2, np.sqrt(var2), int(T/2))\n",
    "\n",
    "    Y11 = np.random.binomial(n=1, p = mu1, size = int(T/2))\n",
    "    Y12 = np.random.binomial(n=1, p = eta_hat, size = int(T/2))\n",
    "    \n",
    "    if np.mean(Y11) > (np.mean(Y12)):\n",
    "        #Y2 = np.random.normal(mu1, np.sqrt(var1), m * T)\n",
    "        Y2 = np.random.binomial(n=1, p = mu1, size = int(m*T))\n",
    "        theta_hat = np.mean(np.concatenate([Y11, Y2]))\n",
    "    else:\n",
    "        theta_hat = np.mean(Y11)\n",
    "\n",
    "        \n",
    "    return theta_hat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 209,
   "id": "01e4c987-df86-4476-bb70-088eb1bf5d4e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def test(T, theta_hat, mu10, eta_hat, var1, var2 ,alpha=0.1, M=1000):\n",
    "    # Simulate M draws of the test stat under (mu1, mu2) = (mu10, eta_hat)\n",
    "    theta_hat_sims = [ETC_sim(T, mu1=mu10, eta_hat=eta_hat, var1=var1, var2=var2) for _ in range(M)]\n",
    "    # Do I reject mu1 = mu10 at sig level alpha \n",
    "    return np.mean(theta_hat > theta_hat_sims)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 220,
   "id": "aab7e8d9-8c79-42da-9f7e-39fb492a4d7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "T = 5000\n",
    "mu1, mu2 = 0.5, 0.5\n",
    "N = 50000\n",
    "m = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 221,
   "id": "7dca1f0a-4478-4c1f-a409-23ac64c698d7",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████| 50000/50000 [2:51:16<00:00,  4.87it/s]\n"
     ]
    }
   ],
   "source": [
    "# Draw the data N times, see how many times the test rejects\n",
    "quantiles = []\n",
    "quantiles_biased = []\n",
    "eta_hat_vals = []\n",
    "theta_hat_vals = []\n",
    "\n",
    "with tqdm(total=N) as pbar:\n",
    "    for i in range(N):\n",
    "        np.random.seed(i)\n",
    "        theta_hat, eta_biased, eta_hat, var1, var2 = ETC(T, mu1, mu2)\n",
    "        eta_hat_vals.append(eta_hat)\n",
    "        theta_hat_vals.append(theta_hat)\n",
    "        quantiles.append(test(T, theta_hat, mu1, eta_hat, var1, var2))\n",
    "        quantiles_biased.append(test(T, theta_hat, mu1, eta_biased, var1 ,var2))\n",
    "        pbar.update(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 213,
   "id": "3eb31eba-ae6b-456a-a4ae-d0029fa3fbb3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([5192., 5112., 5478., 6084., 6389., 6513., 6117., 4974., 3144.,\n",
       "         997.]),\n",
       " array([0.    , 0.0999, 0.1998, 0.2997, 0.3996, 0.4995, 0.5994, 0.6993,\n",
       "        0.7992, 0.8991, 0.999 ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 213,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(quantiles, color = \"blue\", alpha = 0.5, bins = 10)\n",
    "plt.hist(quantiles_biased, color = \"red\", alpha = 0.5, bins = 10)\n",
    "### keep quantiles biased"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 219,
   "id": "4a44b61f-1563-4b6d-9a78-6181e074e58a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.16028\n",
      "0.25166\n"
     ]
    }
   ],
   "source": [
    "alpha = 0.25\n",
    "print((np.sum(np.array(quantiles_biased) < alpha/2) + np.sum(np.array(quantiles_biased) > 1-alpha/2))/len(quantiles_biased))\n",
    "print((np.sum(np.array(quantiles) < alpha/2) + np.sum(np.array(quantiles) > 1-alpha/2))/len(quantiles))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b2406429-c54d-4a47-844f-5bc8de112a2a",
   "metadata": {},
   "outputs": [],
   "source": [
    "alpha = np.linspace(0, 1, 100)\n",
    "rejection_prob_biased = np.zeros(100)\n",
    "rejection_prob_naive = np.zeros(100)\n",
    "\n",
    "for i in range(100):\n",
    "    rejection_prob_biased[i] = (np.sum(np.array(quantiles_biased) < alpha/2) + np.sum(np.array(quantiles_biased) > 1-alpha/2))/len(quantiles_biased)\n",
    "    rejection_prob_naive[i] = (np.sum(np.array(quantiles) < alpha/2) + np.sum(np.array(quantiles) > 1-alpha/2))/len(quantiles)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "id": "1d0179c4-0e4d-4b1d-addb-28f9dbc8f168",
   "metadata": {},
   "outputs": [],
   "source": [
    "quantiles_biased_T_5000 = quantiles_biased\n",
    "quantiles_plugin_T_5000 = quantiles"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a703f6b3-279a-44b0-938c-77bc077ee652",
   "metadata": {},
   "outputs": [],
   "source": [
    "###### Dont change this block"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 189,
   "id": "365a5b3d-3954-4a67-a93d-9e6c62ba2eaa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.20519127838077056\n"
     ]
    }
   ],
   "source": [
    "from scipy import stats\n",
    "uniform_samples = np.random.uniform(size= N)\n",
    "ks_test_for_uniform = (stats.ks_2samp(quantiles, uniform_samples))\n",
    "print(ks_test_for_uniform.pvalue)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "6d343a8d-9682-42bc-a208-3e6b3adfd6ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([1003., 1003., 1002., 1036.,  981.,  988.,  995., 1011., 1003.,\n",
       "         978.]),\n",
       " array([5.96272935e-06, 9.99844135e-02, 1.99962864e-01, 2.99941315e-01,\n",
       "        3.99919766e-01, 4.99898216e-01, 5.99876667e-01, 6.99855118e-01,\n",
       "        7.99833569e-01, 8.99812020e-01, 9.99790470e-01]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjEAAAGdCAYAAADjWSL8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAhaElEQVR4nO3df3TT5fn/8Vdp2lJ62ghFEioVy05VtKhYFCk62IAyFZmHbbDBOOiqg4MiFRDpwSl4XHtALUxRHBwGjB/CmROn56BSNldBUKHCJuCBTRjSQa1oTYt0LT/u7x8e8vmmRaQ1aXqV5+OcnLO8cydcuQ8jT99J2hjnnBMAAIAx7aI9AAAAQHMQMQAAwCQiBgAAmETEAAAAk4gYAABgEhEDAABMImIAAIBJRAwAADDJE+0BIuX06dM6fPiwkpOTFRMTE+1xAADAeXDOqaamRmlpaWrX7tznWtpsxBw+fFjp6enRHgMAADTDoUOH1K1bt3OuabMRk5ycLOnrTUhJSYnyNAAA4HxUV1crPT09+Dp+Lm02Ys68hZSSkkLEAABgzPl8FIQP9gIAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmeaI9AACg9ZpXsi/aIzTZg0Muj/YIaCGciQEAACYRMQAAwCQiBgAAmETEAAAAk4gYAABgEhEDAABMImIAAIBJRAwAADCJiAEAACYRMQAAwCQiBgAAmETEAAAAk4gYAABgEhEDAABMImIAAIBJRAwAADCJiAEAACYRMQAAwCQiBgAAmETEAAAAk4gYAABgEhEDAABMImIAAIBJRAwAADCJiAEAACZ5oj0AAADhNK9kX7RHaJYHh1we7RHM4UwMAAAwiTMxQLi9VRTtCZruBwXRngAAmoyIAYAWYvVtDqC14u0kAABgEhEDAABMImIAAIBJRAwAADCJiAEAACY1OWLefvtt3XHHHUpLS1NMTIxeeeWVkNudc5o1a5bS0tKUmJiogQMHavfu3SFr6urqNGnSJHXu3FlJSUkaPny4ysvLQ9ZUVVVp7Nix8nq98nq9Gjt2rL788ssmP0EAANA2Nfkr1l999ZWuvfZa3X333frJT37S6Pa5c+equLhYy5Yt0+WXX64nnnhCQ4YM0d69e5WcnCxJys/P12uvvaY1a9YoNTVVU6dO1bBhw1RWVqbY2FhJ0ujRo1VeXq433nhDkvTrX/9aY8eO1WuvvfZdni8AoAlu+mRRtEdosncv/XW0R0ALaXLE3Hrrrbr11lvPeptzTvPnz9fMmTM1YsQISdLy5cvl8/m0evVqjR8/XoFAQEuWLNGKFSs0ePBgSdLKlSuVnp6ujRs3aujQofroo4/0xhtv6N1331Xfvn0lSYsXL1a/fv20d+9eXXHFFc19vgAAoI0I62diDhw4oIqKCuXm5gaPJSQkaMCAAdqyZYskqaysTCdOnAhZk5aWpqysrOCarVu3yuv1BgNGkm666SZ5vd7gGgAAcGEL60/sraiokCT5fL6Q4z6fTwcPHgyuiY+PV8eOHRutOXP/iooKdenSpdHjd+nSJbimobq6OtXV1QWvV1dXN/+JnA+LP1reoK37P4/2CE3Wr0dqtEcALmgW3wKTpHkl9t4Gi/YvrYzIrx2IiYkJue6ca3SsoYZrzrb+XI9TVFSk2bNnN2NaABbxI/wBhDVi/H6/pK/PpHTt2jV4vLKyMnh2xu/3q76+XlVVVSFnYyorK5WTkxNc8+mnnzZ6/M8++6zRWZ4zCgoKNGXKlOD16upqpaenf/cnBQBhYvUMAdBahfUzMRkZGfL7/SopKQkeq6+vV2lpaTBQsrOzFRcXF7LmyJEj2rVrV3BNv379FAgE9P777wfXvPfeewoEAsE1DSUkJCglJSXkAgAA2q4mn4k5duyY/v3vfwevHzhwQDt37lSnTp106aWXKj8/X4WFhcrMzFRmZqYKCwvVoUMHjR49WpLk9XqVl5enqVOnKjU1VZ06ddK0adPUq1ev4LeVevbsqR/96Ee699579fvf/17S11+xHjZsGN9MAiCJsxoAmhEx27dv1w9+8IPg9TNv4YwbN07Lli3T9OnTVVtbq4kTJ6qqqkp9+/bVhg0bgj8jRpLmzZsnj8ejkSNHqra2VoMGDdKyZcuCPyNGklatWqUHHngg+C2m4cOHa8GCBc1+ogAAoG2Jcc65aA8RCdXV1fJ6vQoEApF5a4lvJ7UIvp3UQn5QEO0JmmzrkmnRHgEIK4s/pC8S305qyut3RL6dBMAYohyAQUQMAACtgM3PeT0V1T+d32INAABMImIAAIBJRAwAADCJiAEAACbxwV4gzPhaOAC0DM7EAAAAk4gYAABgEhEDAABMImIAAIBJfLD3AmLxA6doGfzdAGAREdNM/KMPAEB08XYSAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATAp7xJw8eVKPPPKIMjIylJiYqB49eujxxx/X6dOng2ucc5o1a5bS0tKUmJiogQMHavfu3SGPU1dXp0mTJqlz585KSkrS8OHDVV5eHu5xAQCAUWGPmDlz5uiFF17QggUL9NFHH2nu3Ll68skn9eyzzwbXzJ07V8XFxVqwYIG2bdsmv9+vIUOGqKamJrgmPz9f69at05o1a7R582YdO3ZMw4YN06lTp8I9MgAAMMgT7gfcunWrfvzjH+v222+XJF122WV68cUXtX37dklfn4WZP3++Zs6cqREjRkiSli9fLp/Pp9WrV2v8+PEKBAJasmSJVqxYocGDB0uSVq5cqfT0dG3cuFFDhw4N99gAAMCYsJ+Jufnmm/XXv/5V+/btkyT94x//0ObNm3XbbbdJkg4cOKCKigrl5uYG75OQkKABAwZoy5YtkqSysjKdOHEiZE1aWpqysrKCaxqqq6tTdXV1yAUAALRdYT8T8/DDDysQCOjKK69UbGysTp06pd/+9rf6xS9+IUmqqKiQJPl8vpD7+Xw+HTx4MLgmPj5eHTt2bLTmzP0bKioq0uzZs8P9dAAAQCsV9jMxa9eu1cqVK7V69Wp98MEHWr58uZ566iktX748ZF1MTEzIdedco2MNnWtNQUGBAoFA8HLo0KHv9kQAAECrFvYzMQ899JBmzJihn//855KkXr166eDBgyoqKtK4cePk9/slfX22pWvXrsH7VVZWBs/O+P1+1dfXq6qqKuRsTGVlpXJycs765yYkJCghISHcTwcAALRSYT8Tc/z4cbVrF/qwsbGxwa9YZ2RkyO/3q6SkJHh7fX29SktLg4GSnZ2tuLi4kDVHjhzRrl27vjFiAADAhSXsZ2LuuOMO/fa3v9Wll16qq6++Wjt27FBxcbF+9atfSfr6baT8/HwVFhYqMzNTmZmZKiwsVIcOHTR69GhJktfrVV5enqZOnarU1FR16tRJ06ZNU69evYLfVgIAABe2sEfMs88+q9/85jeaOHGiKisrlZaWpvHjx+vRRx8Nrpk+fbpqa2s1ceJEVVVVqW/fvtqwYYOSk5ODa+bNmyePx6ORI0eqtrZWgwYN0rJlyxQbGxvukQEAgEExzjkX7SEiobq6Wl6vV4FAQCkpKWF//K1LpoX9MQEAsKRf3lNhf8ymvH7zu5MAAIBJRAwAADCJiAEAACYRMQAAwCQiBgAAmETEAAAAk4gYAABgEhEDAABMImIAAIBJRAwAADCJiAEAACYRMQAAwCQiBgAAmETEAAAAk4gYAABgEhEDAABMImIAAIBJRAwAADCJiAEAACYRMQAAwCQiBgAAmETEAAAAk4gYAABgEhEDAABMImIAAIBJRAwAADCJiAEAACYRMQAAwCQiBgAAmETEAAAAk4gYAABgEhEDAABMImIAAIBJRAwAADCJiAEAACYRMQAAwCQiBgAAmETEAAAAk4gYAABgEhEDAABMImIAAIBJRAwAADCJiAEAACYRMQAAwCQiBgAAmETEAAAAk4gYAABgEhEDAABMImIAAIBJRAwAADCJiAEAACYRMQAAwKSIRMx///tf/fKXv1Rqaqo6dOig6667TmVlZcHbnXOaNWuW0tLSlJiYqIEDB2r37t0hj1FXV6dJkyapc+fOSkpK0vDhw1VeXh6JcQEAgEFhj5iqqir1799fcXFxev3117Vnzx49/fTTuuiii4Jr5s6dq+LiYi1YsEDbtm2T3+/XkCFDVFNTE1yTn5+vdevWac2aNdq8ebOOHTumYcOG6dSpU+EeGQAAGOQJ9wPOmTNH6enpWrp0afDYZZddFvzfzjnNnz9fM2fO1IgRIyRJy5cvl8/n0+rVqzV+/HgFAgEtWbJEK1as0ODBgyVJK1euVHp6ujZu3KihQ4eGe2wAAGBM2M/EvPrqq+rTp49+9rOfqUuXLurdu7cWL14cvP3AgQOqqKhQbm5u8FhCQoIGDBigLVu2SJLKysp04sSJkDVpaWnKysoKrmmorq5O1dXVIRcAANB2hT1i9u/fr4ULFyozM1NvvvmmJkyYoAceeEB//OMfJUkVFRWSJJ/PF3I/n88XvK2iokLx8fHq2LHjN65pqKioSF6vN3hJT08P91MDAACtSNgj5vTp07r++utVWFio3r17a/z48br33nu1cOHCkHUxMTEh151zjY41dK41BQUFCgQCwcuhQ4e+2xMBAACtWtgjpmvXrrrqqqtCjvXs2VOffPKJJMnv90tSozMqlZWVwbMzfr9f9fX1qqqq+sY1DSUkJCglJSXkAgAA2q6wR0z//v21d+/ekGP79u1T9+7dJUkZGRny+/0qKSkJ3l5fX6/S0lLl5ORIkrKzsxUXFxey5siRI9q1a1dwDQAAuLCF/dtJDz74oHJyclRYWKiRI0fq/fff16JFi7Ro0SJJX7+NlJ+fr8LCQmVmZiozM1OFhYXq0KGDRo8eLUnyer3Ky8vT1KlTlZqaqk6dOmnatGnq1atX8NtKAADgwhb2iLnhhhu0bt06FRQU6PHHH1dGRobmz5+vMWPGBNdMnz5dtbW1mjhxoqqqqtS3b19t2LBBycnJwTXz5s2Tx+PRyJEjVVtbq0GDBmnZsmWKjY0N98gAAMCgGOeci/YQkVBdXS2v16tAIBCRz8dsXTIt7I8JAIAl/fKeCvtjNuX1m9+dBAAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwiYgBAAAmETEAAMAkIgYAAJhExAAAAJOIGAAAYBIRAwAATCJiAACASUQMAAAwKeIRU1RUpJiYGOXn5wePOec0a9YspaWlKTExUQMHDtTu3btD7ldXV6dJkyapc+fOSkpK0vDhw1VeXh7pcQEAgBERjZht27Zp0aJFuuaaa0KOz507V8XFxVqwYIG2bdsmv9+vIUOGqKamJrgmPz9f69at05o1a7R582YdO3ZMw4YN06lTpyI5MgAAMCJiEXPs2DGNGTNGixcvVseOHYPHnXOaP3++Zs6cqREjRigrK0vLly/X8ePHtXr1aklSIBDQkiVL9PTTT2vw4MHq3bu3Vq5cqQ8//FAbN26M1MgAAMCQiEXMfffdp9tvv12DBw8OOX7gwAFVVFQoNzc3eCwhIUEDBgzQli1bJEllZWU6ceJEyJq0tDRlZWUF1zRUV1en6urqkAsAAGi7PJF40DVr1uiDDz7Qtm3bGt1WUVEhSfL5fCHHfT6fDh48GFwTHx8fcgbnzJoz92+oqKhIs2fPDsf4AADAgLCfiTl06JAmT56slStXqn379t+4LiYmJuS6c67RsYbOtaagoECBQCB4OXToUNOHBwAAZoQ9YsrKylRZWans7Gx5PB55PB6VlpbqmWeekcfjCZ6BaXhGpbKyMnib3+9XfX29qqqqvnFNQwkJCUpJSQm5AACAtivsETNo0CB9+OGH2rlzZ/DSp08fjRkzRjt37lSPHj3k9/tVUlISvE99fb1KS0uVk5MjScrOzlZcXFzImiNHjmjXrl3BNQAA4MIW9s/EJCcnKysrK+RYUlKSUlNTg8fz8/NVWFiozMxMZWZmqrCwUB06dNDo0aMlSV6vV3l5eZo6dapSU1PVqVMnTZs2Tb169Wr0QWEAAHBhisgHe7/N9OnTVVtbq4kTJ6qqqkp9+/bVhg0blJycHFwzb948eTwejRw5UrW1tRo0aJCWLVum2NjYaIwMAABamRjnnIv2EJFQXV0tr9erQCAQkc/HbF0yLeyPCQCAJf3yngr7Yzbl9ZvfnQQAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJoU9YoqKinTDDTcoOTlZXbp00Z133qm9e/eGrHHOadasWUpLS1NiYqIGDhyo3bt3h6ypq6vTpEmT1LlzZyUlJWn48OEqLy8P97gAAMCosEdMaWmp7rvvPr377rsqKSnRyZMnlZubq6+++iq4Zu7cuSouLtaCBQu0bds2+f1+DRkyRDU1NcE1+fn5WrdundasWaPNmzfr2LFjGjZsmE6dOhXukQEAgEExzjkXyT/gs88+U5cuXVRaWqrvf//7cs4pLS1N+fn5evjhhyV9fdbF5/Npzpw5Gj9+vAKBgC6++GKtWLFCo0aNkiQdPnxY6enpWr9+vYYOHfqtf251dbW8Xq8CgYBSUlLC/ry2LpkW9scEAMCSfnlPhf0xm/L6HfHPxAQCAUlSp06dJEkHDhxQRUWFcnNzg2sSEhI0YMAAbdmyRZJUVlamEydOhKxJS0tTVlZWcE1DdXV1qq6uDrkAAIC2K6IR45zTlClTdPPNNysrK0uSVFFRIUny+Xwha30+X/C2iooKxcfHq2PHjt+4pqGioiJ5vd7gJT09PdxPBwAAtCIRjZj7779f//znP/Xiiy82ui0mJibkunOu0bGGzrWmoKBAgUAgeDl06FDzBwcAAK1exCJm0qRJevXVV/XWW2+pW7duweN+v1+SGp1RqaysDJ6d8fv9qq+vV1VV1TeuaSghIUEpKSkhFwAA0HaFPWKcc7r//vv18ssv629/+5syMjJCbs/IyJDf71dJSUnwWH19vUpLS5WTkyNJys7OVlxcXMiaI0eOaNeuXcE1AADgwuYJ9wPed999Wr16tf7yl78oOTk5eMbF6/UqMTFRMTExys/PV2FhoTIzM5WZmanCwkJ16NBBo0ePDq7Ny8vT1KlTlZqaqk6dOmnatGnq1auXBg8eHO6RAQCAQWGPmIULF0qSBg4cGHJ86dKluuuuuyRJ06dPV21trSZOnKiqqir17dtXGzZsUHJycnD9vHnz5PF4NHLkSNXW1mrQoEFatmyZYmNjwz0yAAAwKOI/JyZa+DkxAABEVpv/OTEAAACRQMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGBSq4+Y559/XhkZGWrfvr2ys7O1adOmaI8EAABagVYdMWvXrlV+fr5mzpypHTt26JZbbtGtt96qTz75JNqjAQCAKGvVEVNcXKy8vDzdc8896tmzp+bPn6/09HQtXLgw2qMBAIAo80R7gG9SX1+vsrIyzZgxI+R4bm6utmzZ0mh9XV2d6urqgtcDgYAkqbq6OiLzfVVb9+2LAABowyLxGnvmMZ1z37q21UbM0aNHderUKfl8vpDjPp9PFRUVjdYXFRVp9uzZjY6np6dHbEYAAC5okxZE7KFramrk9XrPuabVRswZMTExIdedc42OSVJBQYGmTJkSvH769Gl98cUXSk1NPev676K6ulrp6ek6dOiQUlJSwvrY+D/sc8tgn1sG+9wy2OeWE6m9ds6ppqZGaWlp37q21UZM586dFRsb2+isS2VlZaOzM5KUkJCghISEkGMXXXRRJEdUSkoK/ydpAexzy2CfWwb73DLY55YTib3+tjMwZ7TaD/bGx8crOztbJSUlIcdLSkqUk5MTpakAAEBr0WrPxEjSlClTNHbsWPXp00f9+vXTokWL9Mknn2jChAnRHg0AAERZq46YUaNG6fPPP9fjjz+uI0eOKCsrS+vXr1f37t2jOldCQoIee+yxRm9fIbzY55bBPrcM9rllsM8tpzXsdYw7n+8wAQAAtDKt9jMxAAAA50LEAAAAk4gYAABgEhEDAABMImK+wfPPP6+MjAy1b99e2dnZ2rRp0znXl5aWKjs7W+3bt1ePHj30wgsvtNCktjVln19++WUNGTJEF198sVJSUtSvXz+9+eabLTitXU39+3zGO++8I4/Ho+uuuy6yA7YRTd3nuro6zZw5U927d1dCQoK+973v6Q9/+EMLTWtXU/d51apVuvbaa9WhQwd17dpVd999tz7//PMWmtamt99+W3fccYfS0tIUExOjV1555VvvE5XXQYdG1qxZ4+Li4tzixYvdnj173OTJk11SUpI7ePDgWdfv37/fdejQwU2ePNnt2bPHLV682MXFxbmXXnqphSe3pan7PHnyZDdnzhz3/vvvu3379rmCggIXFxfnPvjggxae3Jam7vMZX375pevRo4fLzc111157bcsMa1hz9nn48OGub9++rqSkxB04cMC999577p133mnBqe1p6j5v2rTJtWvXzv3ud79z+/fvd5s2bXJXX321u/POO1t4clvWr1/vZs6c6f785z87SW7dunXnXB+t10Ei5ixuvPFGN2HChJBjV155pZsxY8ZZ10+fPt1deeWVIcfGjx/vbrrppojN2BY0dZ/P5qqrrnKzZ88O92htSnP3edSoUe6RRx5xjz32GBFzHpq6z6+//rrzer3u888/b4nx2oym7vOTTz7pevToEXLsmWeecd26dYvYjG3N+URMtF4HeTupgfr6epWVlSk3NzfkeG5urrZs2XLW+2zdurXR+qFDh2r79u06ceJExGa1rDn73NDp06dVU1OjTp06RWLENqG5+7x06VJ9/PHHeuyxxyI9YpvQnH1+9dVX1adPH82dO1eXXHKJLr/8ck2bNk21tbUtMbJJzdnnnJwclZeXa/369XLO6dNPP9VLL72k22+/vSVGvmBE63WwVf/E3mg4evSoTp061eiXTPp8vka/jPKMioqKs64/efKkjh49qq5du0ZsXquas88NPf300/rqq680cuTISIzYJjRnn//1r39pxowZ2rRpkzwe/ok4H83Z5/3792vz5s1q37691q1bp6NHj2rixIn64osv+FzMN2jOPufk5GjVqlUaNWqU/ve//+nkyZMaPny4nn322ZYY+YIRrddBzsR8g5iYmJDrzrlGx75t/dmOI1RT9/mMF198UbNmzdLatWvVpUuXSI3XZpzvPp86dUqjR4/W7Nmzdfnll7fUeG1GU/4+nz59WjExMVq1apVuvPFG3XbbbSouLtayZcs4G/MtmrLPe/bs0QMPPKBHH31UZWVleuONN3TgwAF+B18ERON1kP/MaqBz586KjY1tVPWVlZWNKvMMv99/1vUej0epqakRm9Wy5uzzGWvXrlVeXp7+9Kc/afDgwZEc07ym7nNNTY22b9+uHTt26P7775f09Yutc04ej0cbNmzQD3/4wxaZ3ZLm/H3u2rWrLrnkEnm93uCxnj17yjmn8vJyZWZmRnRmi5qzz0VFRerfv78eeughSdI111yjpKQk3XLLLXriiSc4Ux4m0Xod5ExMA/Hx8crOzlZJSUnI8ZKSEuXk5Jz1Pv369Wu0fsOGDerTp4/i4uIiNqtlzdln6eszMHfddZdWr17Ne9rnoan7nJKSog8//FA7d+4MXiZMmKArrrhCO3fuVN++fVtqdFOa8/e5f//+Onz4sI4dOxY8tm/fPrVr107dunWL6LxWNWefjx8/rnbtQl/qYmNjJf3fmQJ8d1F7HYzox4aNOvMVviVLlrg9e/a4/Px8l5SU5P7zn/8455ybMWOGGzt2bHD9ma+WPfjgg27Pnj1uyZIlfMX6PDR1n1evXu08Ho977rnn3JEjR4KXL7/8MlpPwYSm7nNDfDvp/DR1n2tqaly3bt3cT3/6U7d7925XWlrqMjMz3T333BOtp2BCU/d56dKlzuPxuOeff959/PHHbvPmza5Pnz7uxhtvjNZTMKGmpsbt2LHD7dixw0lyxcXFbseOHcGvsreW10Ei5hs899xzrnv37i4+Pt5df/31rrS0NHjbuHHj3IABA0LW//3vf3e9e/d28fHx7rLLLnMLFy5s4Yltaso+DxgwwElqdBk3blzLD25MU/8+//+ImPPX1H3+6KOP3ODBg11iYqLr1q2bmzJlijt+/HgLT21PU/f5mWeecVdddZVLTEx0Xbt2dWPGjHHl5eUtPLUtb7311jn/vW0tr4MxznE+DQAA2MNnYgAAgElEDAAAMImIAQAAJhExAADAJCIGAACYRMQAAACTiBgAAGASEQMAAEwiYgAAgElEDAAAMImIAQAAJhExAADApP8HXlTQJjKbl5EAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(rejects, alpha = 0.5, label = \"\")\n",
    "plt.hist(uniform_samples, alpha = 0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d3a86dd-bc71-4379-92b8-357e207f63b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "## alpha_levels based on test\n",
    "alpha "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 193,
   "id": "151a6fe6-116d-4958-964f-37efb3290cf1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████| 10000/10000 [2:07:22<00:00,  1.31it/s]\n"
     ]
    }
   ],
   "source": [
    "# Draw the data N times, see how many times the test rejects\n",
    "rejects = []\n",
    "eta_hat_vals = []\n",
    "theta_hat_vals = []\n",
    "\n",
    "\n",
    "\n",
    "with tqdm(total=N) as pbar:\n",
    "    for i in range(N):\n",
    "        theta_hat, eta_obs, eta_hat = ETC(T, mu1, mu2, sigma1, sigma2)\n",
    "        eta_hat_vals.append(eta_hat)\n",
    "        theta_hat_vals.append(theta_hat)\n",
    "        rejects.append(test_noisy(T, theta_hat, mu1, eta_hat=eta_hat))\n",
    "        pbar.update(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 195,
   "id": "15be32d8-c84f-4ba6-b6d3-239eb35fa771",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 152.,  456.,  910., 1433., 1825., 1589., 1059.,  796.,  821.,\n",
       "         959.]),\n",
       " array([0.005 , 0.1045, 0.204 , 0.3035, 0.403 , 0.5025, 0.602 , 0.7015,\n",
       "        0.801 , 0.9005, 1.    ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 195,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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UlKi4uJi+/GlS5f0l7/8Rf369Wu3viMCgYDS09N16tQpJSUldcox0Rbz3HWY667BPHcd5rrrRGquLctSY2OjvF7vdWu7bYhJSUlRTExMm1WXurq6NqszkuR0OuV0OkPGvvKVr0Skt6SkJP7j6ALMc9dhrrsG89x1mOuuE4m5vt4KzGXd9sLe+Ph4ZWVlqaKiImS8oqJCOTk5UeoKAAB0F912JUaSiouLVVBQoFGjRik7O1v/8R//oU8++USPPfZYtFsDAABR1q1DzKxZs3T+/Hn927/9m2pra5WZmaktW7YoIyMjKv04nU4999xzbd62QudinrsOc901mOeuw1x3ne4w1w7rRu5hAgAA6Ga67TUxAAAA10KIAQAARiLEAAAAIxFiAACAkQgxX/LKK69o4MCB6tWrl7KysrRjx45r1m/btk1ZWVnq1auXbr/9dv37v/97F3VqvnDm+q233tK9996rW2+9VUlJScrOztbvf//7LuzWbOH+XV/2xz/+UbGxsfrmN78Z2QZ7iHDnORgM6tlnn1VGRoacTqe+9rWv6fXXX++ibs0W7lyXlZVp+PDh6tOnjzwej/7pn/5J58+f76JuzbR9+3ZNmzZNXq9XDodDmzZtuu5zovKaaMGyLMtav369FRcXZ61cudI6evSo9dRTT1kJCQnWn//853brP/74Y6tPnz7WU089ZR09etRauXKlFRcXZ/3617/u4s7NE+5cP/XUU9aPf/xja+/evdYHH3xglZSUWHFxcdaBAwe6uHPzhDvXlzU0NFi33367lZubaw0fPrxrmjVYR+Y5Pz/fGj16tFVRUWHV1NRYe/bssf74xz92YddmCneud+zYYd1yyy3WT3/6U+vjjz+2duzYYd15553W/fff38Wdm2XLli3Ws88+a/3Xf/2XJcnauHHjNeuj9ZpIiPk/d911l/XYY4+FjH3961+3Fi9e3G79008/bX39618PGXv00UetMWPGRKzHniLcuW7PHXfcYS1durSzW+txOjrXs2bNsv71X//Veu655wgxNyDcef7d735nuVwu6/z5813RXo8S7lz/5Cc/sW6//faQsZ/97GdW//79I9ZjT3MjISZar4m8nSSpublZVVVVys3NDRnPzc1VZWVlu8/ZtWtXm/pJkyZp//79amlpiVivpuvIXF/p0qVLamxsVHJyciRa7DE6OterV6/WRx99pOeeey7SLfYIHZnnt99+W6NGjdKLL76or371qxo8eLAWLVqkixcvdkXLxurIXOfk5Oj06dPasmWLLMvS2bNn9etf/1pTpkzpipZvGtF6TezWn9jbVc6dO6fW1tY2XyyZlpbW5gsoL/P5fO3Wf/755zp37pw8Hk/E+jVZR+b6Si+99JIuXLigmTNnRqLFHqMjc33ixAktXrxYO3bsUGws/zzciI7M88cff6ydO3eqV69e2rhxo86dO6fHH39cf/nLX7gu5ho6Mtc5OTkqKyvTrFmz9Ne//lWff/658vPz9fOf/7wrWr5pROs1kZWYL3E4HCGPLctqM3a9+vbG0Va4c33Zf/7nf2rJkiXasGGDUlNTI9Vej3Kjc93a2qrZs2dr6dKlGjx4cFe112OE8zd96dIlORwOlZWV6a677tJ9992nZcuWac2aNazG3IBw5vro0aNasGCBfvjDH6qqqkrl5eWqqanhO/giIBqvifyvlqSUlBTFxMS0SfJ1dXVtkuVlbre73frY2Fj169cvYr2ariNzfdmGDRs0b948/epXv9LEiRMj2WaPEO5cNzY2av/+/Tp48KCefPJJSV+82FqWpdjYWL3zzju65557uqR3k3Tkb9rj8eirX/2qXC6XPTZ06FBZlqXTp09r0KBBEe3ZVB2Z69LSUt199936l3/5F0nSN77xDSUkJOhb3/qWfvSjH7Fq3kmi9ZrISoyk+Ph4ZWVlqaKiImS8oqJCOTk57T4nOzu7Tf0777yjUaNGKS4uLmK9mq4jcy19sQIzd+5cvfnmm7yXfYPCneukpCQdOnRI1dXV9vbYY49pyJAhqq6u1ujRo7uqdaN05G/67rvv1pkzZ9TU1GSPffDBB7rlllvUv3//iPZrso7M9WeffaZbbgl9qYuJiZH0/ysF+NtF7TUxopcNG+TybXurVq2yjh49ahUVFVkJCQnWyZMnLcuyrMWLF1sFBQV2/eXbyf75n//ZOnr0qLVq1Spusb5B4c71m2++acXGxlq/+MUvrNraWntraGiI1ikYI9y5vhJ3J92YcOe5sbHR6t+/v/Xtb3/bOnLkiLVt2zZr0KBB1sMPPxytUzBGuHO9evVqKzY21nrllVesjz76yNq5c6c1atQo66677orWKRihsbHROnjwoHXw4EFLkrVs2TLr4MGD9q3s3eU1kRDzJb/4xS+sjIwMKz4+3ho5cqS1bds2e9+cOXOssWPHhtS///771ogRI6z4+HhrwIAB1quvvtrFHZsrnLkeO3asJanNNmfOnK5v3EDh/l1/GSHmxoU7z8eOHbMmTpxo9e7d2+rfv79VXFxsffbZZ13ctZnCneuf/exn1h133GH17t3b8ng81kMPPWSdPn26i7s2y3vvvXfNf3e7y2uiw7JYTwMAAObhmhgAAGAkQgwAADASIQYAABiJEAMAAIxEiAEAAEYixAAAACMRYgAAgJEIMQAAwEiEGAAAYCRCDAAAMBIhBgAAGIkQAwAAjPS/kImzNpk4DBEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(rejects)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 186,
   "id": "22bafc1f-f75f-4627-83e9-2d7a3f371833",
   "metadata": {},
   "outputs": [],
   "source": [
    "T = 5000\n",
    "noise = np.sqrt(np.log(T)/T)\n",
    "theta_hat_sims_pos = [ETC(T, mu1=mu1, mu2=mu2 + noise, sigma1=sigma1, sigma2=sigma2)[0] for _ in range(5000)]\n",
    "#theta_hat_sims_neg = [ETC(T, mu1=mu1, mu2=mu2 - noise, sigma1=sigma1, sigma2=sigma2)[0] for _ in range(5000)]\n",
    "theta_hat_sims_true = [ETC(T, mu1=mu1, mu2=mu2, sigma1=sigma1, sigma2=sigma2)[0] for _ in range(5000)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "id": "f7cb1474-12b0-4685-b3a2-146750a5bcfd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.012750680797831619\n",
      "-0.0473075661771968\n"
     ]
    }
   ],
   "source": [
    "print(theta_hat)\n",
    "print(eta_hat)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 187,
   "id": "161152ff-710e-4ca1-8b88-8947df68dfe7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.lines.Line2D at 0x176738710>"
      ]
     },
     "execution_count": 187,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjEAAAGdCAYAAADjWSL8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAw2klEQVR4nO3de3xU9Z3/8fc0NyAkIwlmhqkBcZdFMHiLGkAtscQANURLt4DYLNtlEVcFI+AlD/VntGsCrAJdUFTKCgUR10tYtmURqAWh4RqbcvWCIkJljJc4ITEmIfn+/nA56yQQCcwk+YbX8/E4DzPf8zkn349B8+Y755xxGWOMAAAALPODtp4AAADAmSDEAAAAKxFiAACAlQgxAADASoQYAABgJUIMAACwEiEGAABYiRADAACsFNnWEwiXhoYGffLJJ4qLi5PL5Wrr6QAAgNNgjNGxY8fk8/n0gx80v9bSYUPMJ598ouTk5LaeBgAAOAOHDx/WBRdc0GxNhw0xcXFxkr79lxAfH9/GswGAs1dVVSWfzyfp27+oxcbGtvGMgNCrqKhQcnKy83u8OR02xJx4Cyk+Pp4QA6BDiIiIcL6Oj48nxKBDO51LQbiwFwAAWIkQAwAArESIAQAAViLEAAAAKxFiAACAlQgxAADASoQYAABgJUIMAACwEiEGAABYiRADAACsRIgBAABWIsQAAAArEWIAAICVCDEAAMBKkW09AQBoVbvyQ3euS0N4LgAtxkoMAACwEiEGAABYqcUh5q233tLIkSPl8/nkcrm0cuXKJjX79+9Xdna23G634uLiNHDgQH388cfO/pqaGk2ePFndu3dXbGyssrOzdeTIkaBzlJeXKycnR263W263Wzk5Ofrqq69a3CAAAOiYWhxiqqqqdNlll2n+/Pkn3f/BBx/ouuuu08UXX6wNGzboL3/5ix555BF16tTJqcnNzVVRUZFWrFihzZs3q7KyUllZWaqvr3dqxo0bp9LSUq1Zs0Zr1qxRaWmpcnJyzqBFAADQEbmMMeaMD3a5VFRUpFtuucUZGzt2rKKiorR06dKTHhMIBHT++edr6dKlGjNmjCTpk08+UXJyslavXq1hw4Zp//796t+/v7Zu3aq0tDRJ0tatWzVo0CC988476tu37/fOraKiQm63W4FAQPHx8WfaIoCOZld+6M7Vyhf2VlVVqWvXrpKkyspKxcbGtur3B1pDS35/h/SamIaGBv3+97/X3/3d32nYsGFKSkpSWlpa0FtOJSUlqqurU2ZmpjPm8/mUkpKi4uJiSdKWLVvkdrudACNJAwcOlNvtdmoAAMC5LaQhpqysTJWVlZoxY4aGDx+utWvX6qc//alGjRqljRs3SpL8fr+io6PVrVu3oGM9Ho/8fr9Tk5SU1OT8SUlJTk1jNTU1qqioCNoAAEDHFdLnxDQ0NEiSbr75Zt17772SpMsvv1zFxcV69tlnNWTIkFMea4yRy+VyXn/361PVfFdhYaEee+yxs5k+AACwSEhXYrp3767IyEj1798/aLxfv37O3Uler1e1tbUqLy8PqikrK5PH43FqPv300ybn/+yzz5yaxvLy8hQIBJzt8OHDoWgJAAC0UyENMdHR0br66qv17rvvBo2/99576tWrlyQpNTVVUVFRWrdunbP/6NGj2rNnjwYPHixJGjRokAKBgLZv3+7UbNu2TYFAwKlpLCYmRvHx8UEbAADouFr8dlJlZaUOHDjgvD548KBKS0uVkJCgnj176r777tOYMWP0ox/9SDfccIPWrFmj//7v/9aGDRskSW63WxMmTNC0adOUmJiohIQETZ8+XQMGDFBGRoakb1duhg8frokTJ+q5556TJN1+++3Kyso6rTuTAABAx9fiELNz507dcMMNzuupU6dKksaPH6/Fixfrpz/9qZ599lkVFhZqypQp6tu3r1577TVdd911zjFz5sxRZGSkRo8ererqag0dOlSLFy9WRESEU/Piiy9qypQpzl1M2dnZp3w2DQAAOPec1XNi2jOeEwPgpHblh+5cPCcGCLk2e04MAABAayHEAAAAKxFiAACAlQgxAADASoQYAABgJUIMAACwEiEGAABYiRADAACsRIgBAABWIsQAAAArEWIAAICVCDEAAMBKhBgAAGAlQgwAALASIQYAAFiJEAMAAKxEiAEAAFYixAAAACsRYgAAgJUIMQAAwEqEGAAAYCVCDAAAsBIhBgAAWIkQAwAArESIAQAAViLEAAAAKxFiAACAlQgxAADASoQYAABgJUIMAACwEiEGAABYiRADAACsRIgBAABWanGIeeuttzRy5Ej5fD65XC6tXLnylLWTJk2Sy+XS3Llzg8Zramo0efJkde/eXbGxscrOztaRI0eCasrLy5WTkyO32y23262cnBx99dVXLZ0uAADooFocYqqqqnTZZZdp/vz5zdatXLlS27Ztk8/na7IvNzdXRUVFWrFihTZv3qzKykplZWWpvr7eqRk3bpxKS0u1Zs0arVmzRqWlpcrJyWnpdAEAQAcV2dIDRowYoREjRjRb89e//lV333233njjDd10001B+wKBgBYtWqSlS5cqIyNDkrRs2TIlJydr/fr1GjZsmPbv3681a9Zo69atSktLkyQtXLhQgwYN0rvvvqu+ffu2dNoAAKCDCfk1MQ0NDcrJydF9992nSy65pMn+kpIS1dXVKTMz0xnz+XxKSUlRcXGxJGnLli1yu91OgJGkgQMHyu12OzWN1dTUqKKiImgDAAAdV8hDzMyZMxUZGakpU6acdL/f71d0dLS6desWNO7xeOT3+52apKSkJscmJSU5NY0VFhY618+43W4lJyefZScAAKA9C2mIKSkp0a9//WstXrxYLperRccaY4KOOdnxjWu+Ky8vT4FAwNkOHz7csskDAACrhDTEbNq0SWVlZerZs6ciIyMVGRmpQ4cOadq0abrwwgslSV6vV7W1tSovLw86tqysTB6Px6n59NNPm5z/s88+c2oai4mJUXx8fNAGAAA6rpCGmJycHO3atUulpaXO5vP5dN999+mNN96QJKWmpioqKkrr1q1zjjt69Kj27NmjwYMHS5IGDRqkQCCg7du3OzXbtm1TIBBwagAAwLmtxXcnVVZW6sCBA87rgwcPqrS0VAkJCerZs6cSExOD6qOiouT1ep07itxutyZMmKBp06YpMTFRCQkJmj59ugYMGODcrdSvXz8NHz5cEydO1HPPPSdJuv3225WVlcWdSQAAQNIZhJidO3fqhhtucF5PnTpVkjR+/HgtXrz4tM4xZ84cRUZGavTo0aqurtbQoUO1ePFiRUREODUvvviipkyZ4tzFlJ2d/b3PpgEAAOcOlzHGtPUkwqGiokJut1uBQIDrYwD8n135oTvXpSE812moqqpS165dJX27Kh4bG9uq3x9oDS35/c1nJwEAACsRYgAAgJUIMQAAwEqEGAAAYCVCDAAAsBIhBgAAWIkQAwAArESIAQAAViLEAAAAKxFiAACAlQgxAADASoQYAABgJUIMAACwEiEGAABYiRADAACsRIgBAABWIsQAAAArEWIAAICVCDEAAMBKhBgAAGAlQgwAALASIQYAAFiJEAMAAKxE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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(theta_hat_sims_pos, alpha = 0.5, color = \"blue\", bins = 20)\n",
    "#plt.hist(theta_hat_sims_neg, alpha = 0.5, color = \"red\", bins = 20)\n",
    "plt.hist(theta_hat_sims_true, color = \"orange\", alpha = 0.5, bins = 20)\n",
    "plt.axvline(theta_hat, color = \"black\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5513e55-3be1-471a-baf5-3b70fd6d8bf4",
   "metadata": {},
   "outputs": [],
   "source": [
    "### test confidence interval approach\n",
    "rejects_ci = np.zeros(100)\n",
    "for j in range(100):\n",
    "    rejects_ci[j] = (np.mean(np.random.normal(size=1000)) + 1.281 * np.sqrt(1/1000) < 0.05)\n",
    "print(np.mean(rejects_ci))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "50f3478e-45a9-4f4b-b45d-8168b9f8f6fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.mean(rejects)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c523081d-c942-4206-aa2f-955a6c048cc6",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.scatter(theta_hat_vals, eta_hat_vals)\n",
    "plt.xlabel(\"mu_1_hat\")\n",
    "plt.ylabel(\"mu_2_hat\")\n",
    "plt.axhline(0, color = \"red\")\n",
    "plt.axvline(0, color = \"red\")\n",
    "print(np.sqrt(np.cov(theta_hat_vals, eta_hat_vals) * T))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d91500db-ca63-412b-aaf3-409f1d74b127",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.hist(eta_hat_vals, bins=30, alpha=0.5, label='eta_hat')\n",
    "plt.hist(theta_hat_vals,bins=30, alpha=0.5, label='theta_hat')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1c6b8d35-21bb-4581-ad32-ab023743c578",
   "metadata": {},
   "source": [
    "## Distribution Under Null with New Simulation Procedure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df334ae1-bde7-4a7c-b49f-2cb89c43698f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_plugin_quantile(T, theta_hat, mu10, eta_obs, eta_hat, M=1000):\n",
    "    # Simulate M draws of the test stat under (mu1, mu2) = (mu10, eta_hat)\n",
    "    theta_hat_sims = [ETC_sim(T, mu1=mu10, eta_obs = eta_obs, eta_hat=eta_hat, sigma1=sigma1, sigma2=sigma2) for _ in range(M)]\n",
    "    # Do I reject mu1 = mu10 at sig level alpha \n",
    "    return (theta_hat<theta_hat_sims).mean() ## 1-F\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4fae0a9-3ae5-4913-a3e5-9dc9a6f1de75",
   "metadata": {},
   "outputs": [],
   "source": [
    "T = 1000\n",
    "N = 50000\n",
    "mu1 = 0\n",
    "\n",
    "### for each eta_hat_vals_true, calculate the quantile under the \n",
    "quantiles = []\n",
    "theta_hats = []\n",
    "eta_hats = []\n",
    "with tqdm(total=N) as pbar:\n",
    "    for i in range(N):\n",
    "        theta_hat, eta_obs, eta_hat, = ETC(T, mu1, mu2, sigma1, sigma2)\n",
    "        theta_hats.append(theta_hat)\n",
    "        eta_hats.append(eta_hat)\n",
    "        quantiles.append(get_plugin_quantile(T, theta_hat, mu1, eta_obs, eta_hat))\n",
    "        pbar.update(1)\n",
    "\n",
    "#with tqdm(total=N) as pbar:\n",
    "#    for i in range(N):\n",
    "#        theta_hat, eta_obs, eta_hat = ETC(T, mu1, mu2, sigma1, sigma2)\n",
    "#        eta_hat_vals.append(eta_hat)\n",
    "#        theta_hat_vals.append(theta_hat)\n",
    "#        rejects.append(test(T, theta_hat, mu1, eta_obs, eta_hat))\n",
    "#        pbar.update(1)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c5008cb-91c7-4360-a227-4627378d4aa4",
   "metadata": {},
   "outputs": [],
   "source": [
    "## calcualte the distance between uniform distributions for this test statistic - show that this fails for ETC\n",
    "uniform_samples = np.random.uniform(size=N)\n",
    "\n",
    "plt.hist(1-np.array(quantiles), bins = 20, alpha = 0.5, label = \"realized\")\n",
    "plt.hist(uniform_samples, alpha = 0.5, bins=20 ,label = \"uniform\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0c1adbc-7cc3-4202-8b06-57da096d1538",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy import stats\n",
    "ks_test_for_uniform = (stats.ks_2samp(quantiles, uniform_samples))\n",
    "print(ks_test_for_uniform.pvalue)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "9903eedf-ff52-4a85-8949-afb4996cbea2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([1.00000e+00, 0.00000e+00, 0.00000e+00, 0.00000e+00, 1.00000e+00,\n",
       "        1.00000e+00, 1.00000e+00, 2.00000e+00, 4.00000e+00, 5.00000e+00,\n",
       "        7.00000e+00, 1.40000e+01, 1.40000e+01, 1.90000e+01, 2.50000e+01,\n",
       "        4.30000e+01, 6.50000e+01, 8.80000e+01, 1.45000e+02, 1.79000e+02,\n",
       "        2.61000e+02, 3.68000e+02, 5.52000e+02, 6.50000e+02, 9.55000e+02,\n",
       "        1.30300e+03, 1.69200e+03, 2.32200e+03, 2.92900e+03, 3.75400e+03,\n",
       "        5.01800e+03, 6.37300e+03, 8.16500e+03, 1.05780e+04, 1.31840e+04,\n",
       "        1.65890e+04, 2.04460e+04, 2.49390e+04, 3.03970e+04, 3.64500e+04,\n",
       "        4.41590e+04, 5.17480e+04, 6.10110e+04, 7.13020e+04, 8.34200e+04,\n",
       "        9.50560e+04, 1.09004e+05, 1.23890e+05, 1.39332e+05, 1.56597e+05,\n",
       "        1.75506e+05, 1.94620e+05, 2.16704e+05, 2.41080e+05, 2.66031e+05,\n",
       "        2.93712e+05, 3.21498e+05, 3.51490e+05, 3.81513e+05, 4.09227e+05,\n",
       "        4.35234e+05, 4.57508e+05, 4.73352e+05, 4.81374e+05, 4.82419e+05,\n",
       "        4.71404e+05, 4.54897e+05, 4.27470e+05, 3.93921e+05, 3.54323e+05,\n",
       "        3.13548e+05, 2.70588e+05, 2.27738e+05, 1.87336e+05, 1.50128e+05,\n",
       "        1.18801e+05, 9.11720e+04, 6.94330e+04, 5.07920e+04, 3.65570e+04,\n",
       "        2.59260e+04, 1.76860e+04, 1.20840e+04, 7.90000e+03, 5.09700e+03,\n",
       "        3.42500e+03, 2.17500e+03, 1.29300e+03, 8.22000e+02, 4.92000e+02,\n",
       "        2.70000e+02, 1.76000e+02, 1.03000e+02, 4.50000e+01, 3.10000e+01,\n",
       "        2.40000e+01, 6.00000e+00, 4.00000e+00, 4.00000e+00, 3.00000e+00]),\n",
       " array([-5.61378097, -5.52537484, -5.43696872, -5.34856259, -5.26015647,\n",
       "        -5.17175034, -5.08334421, -4.99493809, -4.90653196, -4.81812584,\n",
       "        -4.72971971, -4.64131358, -4.55290746, -4.46450133, -4.3760952 ,\n",
       "        -4.28768908, -4.19928295, -4.11087683, -4.0224707 , -3.93406457,\n",
       "        -3.84565845, -3.75725232, -3.66884619, -3.58044007, -3.49203394,\n",
       "        -3.40362782, -3.31522169, -3.22681556, -3.13840944, -3.05000331,\n",
       "        -2.96159718, -2.87319106, -2.78478493, -2.69637881, -2.60797268,\n",
       "        -2.51956655, -2.43116043, -2.3427543 , -2.25434817, -2.16594205,\n",
       "        -2.07753592, -1.9891298 , -1.90072367, -1.81231754, -1.72391142,\n",
       "        -1.63550529, -1.54709917, -1.45869304, -1.37028691, -1.28188079,\n",
       "        -1.19347466, -1.10506853, -1.01666241, -0.92825628, -0.83985016,\n",
       "        -0.75144403, -0.6630379 , -0.57463178, -0.48622565, -0.39781952,\n",
       "        -0.3094134 , -0.22100727, -0.13260115, -0.04419502,  0.04421111,\n",
       "         0.13261723,  0.22102336,  0.30942949,  0.39783561,  0.48624174,\n",
       "         0.57464786,  0.66305399,  0.75146012,  0.83986624,  0.92827237,\n",
       "         1.0166785 ,  1.10508462,  1.19349075,  1.28189687,  1.370303  ,\n",
       "         1.45870913,  1.54711525,  1.63552138,  1.7239275 ,  1.81233363,\n",
       "         1.90073976,  1.98914588,  2.07755201,  2.16595814,  2.25436426,\n",
       "         2.34277039,  2.43117651,  2.51958264,  2.60798877,  2.69639489,\n",
       "         2.78480102,  2.87320715,  2.96161327,  3.0500194 ,  3.13842552,\n",
       "         3.22683165]),\n",
       " <BarContainer object of 100 artists>)"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "var_1 = np.random.normal(size = 10000000, loc = 0, scale = 1)\n",
    "nuis = np.random.normal(size = 10000000, loc = 0, scale = 1)\n",
    "var_2 = (var_1 + (var_1 > nuis) * np.random.normal(size = 10000000, loc = 0, scale = np.sqrt(2)))/(1 + (var_1 > nuis) * 2 )\n",
    "\n",
    "plt.hist(var_1, bins = 100, alpha = 0.5)\n",
    "plt.hist(var_2,  bins = 100, alpha = 0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "f222787a-c380-4f87-b526-9fa68a236dbe",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.6173119\n",
      "0.5016869\n"
     ]
    }
   ],
   "source": [
    "x = np.linspace(-3, 0, 100)\n",
    "x = -0.5\n",
    "print(np.mean(var_1 < x) + np.mean(var_1 > np.abs(x)))\n",
    "print(np.mean(var_2 < x) + np.mean(var_2 > np.abs(x)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "02208ecb-e6a2-4657-b2c8-34876a3eb426",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.44055901554641236"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "i = 1\n",
    "stats.norm.ppf(0.95, loc = mus[i], scale = 2 * np.sqrt(mus[i]*(1-mus[i])))\n",
    "stats.norm.ppf(0.05, loc = mus[i], scale = 2 * np.sqrt(mus[i]*(1-mus[i])))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
