{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": 7,
   "id": "b5984af0-bef7-463a-9b0c-1d6087c4631c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# get the number of simulations based on the \n",
    "\n",
    "def ETC(T, mu1, mu2, sigma1, sigma2, m=10):\n",
    "    Y11 = np.random.normal(mu1, sigma1, int(T/2))\n",
    "    Y12 = np.random.normal(mu2, sigma2, int(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",
    "        eta_obs = Y12\n",
    "        theta_hat, eta_hat = np.mean(np.concatenate([Y11, Y2])), np.mean(eta_obs)\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",
    "        eta_obs = np.concatenate([Y12, Y2])\n",
    "        theta_hat, eta_hat = np.mean(Y11), np.mean(eta_obs)\n",
    "        #theta_hat, eta_hat = np.mean(Y11), np.mean(Y12)\n",
    "\n",
    "    return theta_hat, eta_obs, eta_hat\n",
    "\n",
    "#def ETC_sim(T, mu1, eta_obs, eta_hat, sigma1, sigma2, m=10):\n",
    "#    Y11 = np.random.normal(mu1, sigma1, int(T/2))\n",
    "#    Y12 = eta_obs[0:int(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",
    "#    else:\n",
    "#        if len(eta_obs) != T:\n",
    "#            Y2 = np.random.normal(eta_hat, sigma2, m * T)\n",
    "#        else:\n",
    "#            Y2 = eta_obs[int(T/2):len(eta_obs)]\n",
    "        #Y2 = np.random.binomial(n=1, p = mu2, size = int(m*T))\n",
    "#        theta_hat, eta_hat = np.mean(Y11), np.mean(np.concatenate([Y12, Y2]))\n",
    "        #theta_hat, eta_hat = np.mean(Y11), np.mean(Y12)\n",
    "\n",
    "        \n",
    "#    return theta_hat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "01e4c987-df86-4476-bb70-088eb1bf5d4e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def test(T, theta_hat, mu10, eta_obs, eta_hat, 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_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 < np.quantile(theta_hat_sims, alpha)\n",
    "\n",
    "def test_noisy(T, theta_hat, mu10, eta_hat, alpha=0.1, M=1000):\n",
    "    # Simulate M draws of the test stat under (mu1, mu2) = (mu10, eta_hat)\n",
    "    #noise = np.abs(np.random.normal(0, np.sqrt(np.log(T))/np.sqrt(T), 1))\n",
    "    noise =  0.1 * np.sqrt(np.log(T)/T)\n",
    "    theta_hat_sims = [ETC(T, mu1=mu10, mu2=eta_hat + noise, sigma1=sigma1, sigma2=sigma2)[0] for _ in range(M)]\n",
    "    # Do I reject mu1 = mu10 at sig level alpha \n",
    "    #return theta_hat < np.quantile(theta_hat_sims, alpha)\n",
    "    return (theta_hat < theta_hat_sims).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "aab7e8d9-8c79-42da-9f7e-39fb492a4d7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "T = 5000\n",
    "mu1, mu2 = 0, 0\n",
    "sigma1, sigma2 = 1, 1\n",
    "N = 10000\n",
    "m = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7dca1f0a-4478-4c1f-a409-23ac64c698d7",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▋                                    | 201/10000 [02:30<2:03:30,  1.32it/s]"
     ]
    }
   ],
   "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",
    "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": 151,
   "id": "3eb31eba-ae6b-456a-a4ae-d0029fa3fbb3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.046"
      ]
     },
     "execution_count": 151,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(np.array(rejects) < 0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 196,
   "id": "6d343a8d-9682-42bc-a208-3e6b3adfd6ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 979.,  986.,  967., 1030., 1034.,  991., 1010., 1031.,  937.,\n",
       "        1035.]),\n",
       " array([2.41105038e-05, 1.00002494e-01, 1.99980877e-01, 2.99959260e-01,\n",
       "        3.99937643e-01, 4.99916026e-01, 5.99894409e-01, 6.99872792e-01,\n",
       "        7.99851175e-01, 8.99829558e-01, 9.99807941e-01]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 196,
     "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(rejects, alpha = 0.5)\n",
    "plt.hist(np.random.uniform(size= N), alpha = 0.5)"
   ]
  },
  {
   "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)"
   ]
  }
 ],
 "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
}
