{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "95% Bootstrap CI for beta: [0.22952094 0.2790206 ]\n",
      "95% Bootstrap CI for alpha: [2.42957388 2.92707592]\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "X = np.random.gamma(2.6,4,1000)\n",
    "\n",
    "# Define the function to compute MoM estimates\n",
    "def mom_estimates(X):\n",
    "    mean_X = np.mean(X)\n",
    "    var_X = np.var(X, ddof=1)\n",
    "    alpha_hat = mean_X**2 / var_X\n",
    "    beta_hat = mean_X/var_X\n",
    "    return alpha_hat, beta_hat\n",
    "\n",
    "# Bootstrap procedure\n",
    "n = len(X)\n",
    "n_boot = 10000 # Number of bootstrap samples\n",
    "bootstrap_estimates = []\n",
    "bootstrap_estimates_alpha = []\n",
    "for i in range(n_boot):\n",
    "    # Resample with replacement\n",
    "    X_boot = np.random.choice(X, size=n, replace=True)\n",
    "    # Compute the MoM estimates for the bootstrap sample\n",
    "    alpha_boot, beta_boot = mom_estimates(X_boot)\n",
    "    bootstrap_estimates.append(beta_boot)\n",
    "    bootstrap_estimates_alpha.append(alpha_boot)\n",
    "\n",
    "# Compute the 95% bootstrap confidence interval for beta\n",
    "beta_bootstrap_CI = np.percentile(bootstrap_estimates, [2.5, 97.5])\n",
    "alpha_bootstrap_CI = np.percentile(bootstrap_estimates_alpha, [2.5, 97.5])\n",
    "\n",
    "print(f\"95% Bootstrap CI for beta: {beta_bootstrap_CI}\")\n",
    "print(f\"95% Bootstrap CI for alpha: {alpha_bootstrap_CI}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "95% CI for alpha: [(1.0424909385324284, 2.9677926867383038)]\n",
      "95% CI for beta: [(0.7011274800767535, 1.3302140407521763)]\n",
      "95% CI for alpha: [(1.0424909385324284, 2.9677926867383038), (1.595999211352892, 2.3741302962363586)]\n",
      "95% CI for beta: [(0.7011274800767535, 1.3302140407521763), (0.8750709242615998, 1.1287431046775025)]\n",
      "95% CI for alpha: [(1.0424909385324284, 2.9677926867383038), (1.595999211352892, 2.3741302962363586), (1.6885582144382703, 2.260144518437668)]\n",
      "95% CI for beta: [(0.7011274800767535, 1.3302140407521763), (0.8750709242615998, 1.1287431046775025), (0.9012705121405229, 1.0873138001378861)]\n",
      "95% CI for alpha: [(1.0424909385324284, 2.9677926867383038), (1.595999211352892, 2.3741302962363586), (1.6885582144382703, 2.260144518437668), (1.7541080155274102, 2.2326043661091406)]\n",
      "95% CI for beta: [(0.7011274800767535, 1.3302140407521763), (0.8750709242615998, 1.1287431046775025), (0.9012705121405229, 1.0873138001378861), (0.9260691472566052, 1.0816642711358853)]\n",
      "95% CI for alpha: [(1.0424909385324284, 2.9677926867383038), (1.595999211352892, 2.3741302962363586), (1.6885582144382703, 2.260144518437668), (1.7541080155274102, 2.2326043661091406), (1.7744846036225153, 2.1898009221271293)]\n",
      "95% CI for beta: [(0.7011274800767535, 1.3302140407521763), (0.8750709242615998, 1.1287431046775025), (0.9012705121405229, 1.0873138001378861), (0.9260691472566052, 1.0816642711358853), (0.9313386750688135, 1.066567113879109)]\n",
      "95% CI for alpha: [(1.0424909385324284, 2.9677926867383038), (1.595999211352892, 2.3741302962363586), (1.6885582144382703, 2.260144518437668), (1.7541080155274102, 2.2326043661091406), (1.7744846036225153, 2.1898009221271293), (1.797198287682989, 2.170799677347971)]\n",
      "95% CI for beta: [(0.7011274800767535, 1.3302140407521763), (0.8750709242615998, 1.1287431046775025), (0.9012705121405229, 1.0873138001378861), (0.9260691472566052, 1.0816642711358853), (0.9313386750688135, 1.066567113879109), (0.9385818597909666, 1.060153149455578)]\n",
      "95% CI for alpha: [(1.0424909385324284, 2.9677926867383038), (1.595999211352892, 2.3741302962363586), (1.6885582144382703, 2.260144518437668), (1.7541080155274102, 2.2326043661091406), (1.7744846036225153, 2.1898009221271293), (1.797198287682989, 2.170799677347971), (1.8161700520723205, 2.1589307473731334)]\n",
      "95% CI for beta: [(0.7011274800767535, 1.3302140407521763), (0.8750709242615998, 1.1287431046775025), (0.9012705121405229, 1.0873138001378861), (0.9260691472566052, 1.0816642711358853), (0.9313386750688135, 1.066567113879109), (0.9385818597909666, 1.060153149455578), (0.9447912724837125, 1.0562353540463891)]\n",
      "95% CI for alpha: [(1.0424909385324284, 2.9677926867383038), (1.595999211352892, 2.3741302962363586), (1.6885582144382703, 2.260144518437668), (1.7541080155274102, 2.2326043661091406), (1.7744846036225153, 2.1898009221271293), (1.797198287682989, 2.170799677347971), (1.8161700520723205, 2.1589307473731334), (1.8289060292605561, 2.1470423093147515)]\n",
      "95% CI for beta: [(0.7011274800767535, 1.3302140407521763), (0.8750709242615998, 1.1287431046775025), (0.9012705121405229, 1.0873138001378861), (0.9260691472566052, 1.0816642711358853), (0.9313386750688135, 1.066567113879109), (0.9385818597909666, 1.060153149455578), (0.9447912724837125, 1.0562353540463891), (0.9488064773564486, 1.05221969540555)]\n",
      "95% CI for alpha: [(1.0424909385324284, 2.9677926867383038), (1.595999211352892, 2.3741302962363586), (1.6885582144382703, 2.260144518437668), (1.7541080155274102, 2.2326043661091406), (1.7744846036225153, 2.1898009221271293), (1.797198287682989, 2.170799677347971), (1.8161700520723205, 2.1589307473731334), (1.8289060292605561, 2.1470423093147515), (1.8372016466319365, 2.135030233208992)]\n",
      "95% CI for beta: [(0.7011274800767535, 1.3302140407521763), (0.8750709242615998, 1.1287431046775025), (0.9012705121405229, 1.0873138001378861), (0.9260691472566052, 1.0816642711358853), (0.9313386750688135, 1.066567113879109), (0.9385818597909666, 1.060153149455578), (0.9447912724837125, 1.0562353540463891), (0.9488064773564486, 1.05221969540555), (0.950078028903592, 1.0467879239425826)]\n",
      "95% CI for alpha: [(1.0424909385324284, 2.9677926867383038), (1.595999211352892, 2.3741302962363586), (1.6885582144382703, 2.260144518437668), (1.7541080155274102, 2.2326043661091406), (1.7744846036225153, 2.1898009221271293), (1.797198287682989, 2.170799677347971), (1.8161700520723205, 2.1589307473731334), (1.8289060292605561, 2.1470423093147515), (1.8372016466319365, 2.135030233208992), (1.850771492021162, 2.1327471748363314)]\n",
      "95% CI for beta: [(0.7011274800767535, 1.3302140407521763), (0.8750709242615998, 1.1287431046775025), (0.9012705121405229, 1.0873138001378861), (0.9260691472566052, 1.0816642711358853), (0.9313386750688135, 1.066567113879109), (0.9385818597909666, 1.060153149455578), (0.9447912724837125, 1.0562353540463891), (0.9488064773564486, 1.05221969540555), (0.950078028903592, 1.0467879239425826), (0.9546521196720625, 1.0461076719504827)]\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import norm\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "def mom_estimates(X):\n",
    "    mean_X = np.mean(X)\n",
    "    var_X = np.var(X, ddof=1)\n",
    "    alpha_hat = mean_X**2 / var_X\n",
    "    beta_hat = mean_X/var_X\n",
    "    return alpha_hat, beta_hat\n",
    "\n",
    "betas_CI = []\n",
    "alphas_CI = []\n",
    "\n",
    "betas_CI_boot = []\n",
    "alphas_CI_boot = []\n",
    "n_runs=30\n",
    "beta_param = []\n",
    "\n",
    "alpha, beta = 2,1\n",
    "ticks = np.arange(100,5000,500)\n",
    "for N in ticks:\n",
    "    tmp_beta_l = 0\n",
    "    tmp_beta_u = 0\n",
    "    tmp_alpha_l = 0\n",
    "    tmp_alpha_u=0\n",
    "\n",
    "\n",
    "    tmp_beta_l_boot = 0\n",
    "    tmp_beta_u_boot = 0\n",
    "    tmp_alpha_l_boot = 0\n",
    "    tmp_alpha_u_boot=0\n",
    "\n",
    "\n",
    "    for i in range(n_runs):\n",
    "        np.random.seed(i)\n",
    "        X = np.random.gamma(alpha,1/beta,N)\n",
    "\n",
    "\n",
    "        n = len(X)\n",
    "        mean_X = np.mean(X)  # Sample mean\n",
    "        var_X = np.var(X, ddof=1)  # Sample variance (unbiased)\n",
    "\n",
    "        # MoM estimates\n",
    "        alpha_hat = mean_X**2 / var_X\n",
    "        beta_hat = mean_X/var_X\n",
    "\n",
    "        #print(alpha_hat,beta_hat)\n",
    "        # Approximate variances using delta method\n",
    "        var_alpha_hat = (6* alpha_hat**2) / n  #+ beta_hat**4*var_X\n",
    "        #var_alpha_hat = 4*alpha_hat**2/n #+ beta_hat**4*1/n*((6+3*alpha_hat)/alpha_hat - (n-3)/(n-1)*var_X)\n",
    "        #var_beta_hat = (var_X**4 / mean_X**2  * (2 * alpha_hat**2 / n)) + (1 / n * alpha_hat * beta_hat**2)\n",
    "        #var_beta_hat = beta_hat**2/alpha_hat*(1/n + beta_hat**3/alpha_hat*var_X)\n",
    "        var_beta_hat = beta_hat**2/(n*alpha_hat) + beta_hat**6/alpha_hat**2*(2*alpha_hat**2)/beta_hat**4/n\n",
    "\n",
    "        # Confidence level (e.g., 95%)\n",
    "        confidence_level = 0.95\n",
    "        z_alpha_2 = norm.ppf(1 - (1 - confidence_level) / 2)  # Critical value for normal distribution\n",
    "\n",
    "        # Confidence intervals\n",
    "        alpha_CI = (alpha_hat - z_alpha_2 * np.sqrt(var_alpha_hat), alpha_hat + z_alpha_2 * np.sqrt(var_alpha_hat))\n",
    "        beta_CI = (beta_hat - z_alpha_2 * np.sqrt(var_beta_hat), beta_hat + z_alpha_2 * np.sqrt(var_beta_hat))\n",
    "\n",
    "        tmp_alpha_u+= alpha_CI[1]\n",
    "        tmp_alpha_l+=alpha_CI[0]\n",
    "\n",
    "        tmp_beta_l+=beta_CI[0]\n",
    "        tmp_beta_u+=beta_CI[1]\n",
    "\n",
    "\n",
    "        n_boot = 500 # Number of bootstrap samples\n",
    "        bootstrap_estimates = []\n",
    "        bootstrap_estimates_alpha = []\n",
    "        for i in range(n_boot):\n",
    "            # Resample with replacement\n",
    "            X_boot = np.random.choice(X, size=n, replace=True)\n",
    "            # Compute the MoM estimates for the bootstrap sample\n",
    "            alpha_boot, beta_boot = mom_estimates(X_boot)\n",
    "            bootstrap_estimates.append(beta_boot)\n",
    "            bootstrap_estimates_alpha.append(alpha_boot)\n",
    "\n",
    "        # Compute the 95% bootstrap confidence interval for beta\n",
    "        beta_bootstrap_CI = np.percentile(bootstrap_estimates, [2.5, 97.5])\n",
    "        alpha_bootstrap_CI = np.percentile(bootstrap_estimates_alpha, [2.5, 97.5])\n",
    "\n",
    "        tmp_alpha_u_boot+= alpha_bootstrap_CI[1]\n",
    "        tmp_alpha_l_boot+=alpha_bootstrap_CI[0]\n",
    "\n",
    "        tmp_beta_l_boot+=beta_bootstrap_CI[0]\n",
    "        tmp_beta_u_boot+=beta_bootstrap_CI[1]\n",
    "\n",
    "\n",
    "    alphas_CI.append((tmp_alpha_l/n_runs,tmp_alpha_u/n_runs))\n",
    "    betas_CI.append((tmp_beta_l/n_runs,tmp_beta_u/n_runs))\n",
    "\n",
    "    alphas_CI_boot.append((tmp_alpha_l_boot/n_runs,tmp_alpha_u_boot/n_runs))\n",
    "    betas_CI_boot.append((tmp_beta_l_boot/n_runs,tmp_beta_u_boot/n_runs))\n",
    "\n",
    "\n",
    "\n",
    "#beta_param.append((beta_hat,var_beta_hat))\n",
    "\n",
    "    print(f\"95% CI for alpha: {alphas_CI}\")\n",
    "    print(f\"95% CI for beta: {betas_CI}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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l/p+9aJq2LAh6tati3fffReSJMHV1RW7du0qcOuAzMXFBUOHDkVoaCgSEhLw5ptvwsys8Ov3DRo0wJQpU/D111+rK7LfunULH3zwAby9vTFnzhx12zFjxuDll1/G9OnT8fzzz+P27dtYtGhRie+Tl40dOxbffPMNxo0bh1u3bqFZs2Y4fvw4PvvsM/Tv3x+9evUq0XG/+uor/P333xg/fjz27duHoUOHwt3dHQ8ePMCBAwcQEhKCTZs2cdowIqLKTsEibkREpIAhQ4ZIVlZWhVbZfuGFFyQLCwspLi5OCgsLk3r06CG5u7tLVlZWkpeXlzRy5EjpwoULOl/bvXt3ydXVVXry5EmB5+TK1vfv39faP27cOMne3r5A+/yVpOWq1evWrZNmz54tVa9eXbK2tpa6dOkinTlzRuu1GRkZ0qRJk6Tq1atLKpVKAiBFR0dLkiRJaWlp0jvvvCP5+PhIlpaWkqenp/Tqq69Kjx8/1jrGrVu3pD59+kiOjo4SAMnHx0eSJN3VyyVJVPMeMWKEVLVqVcnKykqqVauWNH78eCk9PV3nd5X3WAsXLpTmz58v1axZU7KyspJatmwp7du3T2f7V155RapRo4ZkaWkpVa9eXerYsaP0ySefFPietmzZovO98sZ95coVqXfv3pKjo6NUpUoVacSIEVJMTIwEQProo48KvP/+/fslABIA6a+//irwfP7q5ZIkSTk5OdLChQulZ555RrK0tJSqVasmvfzyy9KdO3e02uXm5kqLFi2S6tSpI9nY2Eht2rSRDh06pLd6ef7PV5iHDx9K06ZNkzw9PSULCwvJx8dHCgoKKvBvU9Tq5bLs7GwpLCxMevbZZyVXV1fJwsJCql69uhQQECBt3LhRysnJkSSJ1cuJiCozlSTlu8GJiIiohOLj4+Hj44NZs2Zh0aJFBj/+kSNH0KNHD2zZsqVAJWoiIiIiY8Th5UREVGr//PMP/v77b3zxxRcwMzPDa6+9pnRIREREREaBhdSIiKjUvv/+e3Tv3h2XL1/Ghg0bUKNGDaVDIiIiIjIKHF5OREREREREVEbY001ERERERERURph0ExEREREREZURJt1EREREREREZYRJNxEREREREVEZYdJNREREREREVEaYdBMRERERERGVESbdRERERERERGWESTcRERERERFRGWHSTURERERERFRGmHQTERERERERlREm3URERERERERlhEk3ERERERERURlh0k1ERERERERURph0ExEREREREZURJt1EREREREREZYRJNxEREREREVEZYdJNREREREREVEaYdBMRERERERGVEQulAzBGubm5uHfvHhwdHaFSqZQOh4iIKjlJkpCcnAwvLy+YmVXe6+U8PxMRkTEp6vmZSbcO9+7dg7e3t9JhEBERablz5w5q1qypdBiK4fmZiIiM0dPOz0y6dXB0dAQgvjwnJyeFoyEiosouKSkJ3t7e6vNTZcXzMxERGZOinp+ZdOsgD1lzcnLiSZ2IiIxGZR9SzfMzEREZo6ednyvvjWFEREREREREZYxJNxEREREREVEZYdJNREREREREVEZ4TzcR0VPk5OQgKytL6TCoArO0tIS5ubnSYRAREVEZUDTpXrFiBVasWIFbt24BAJo0aYIPP/wQAQEBel9z9OhRBAYG4vLly/Dy8sLbb7+NadOmabXZunUrPvjgA9y8eRN169bFp59+iqFDh5blRyGiCkiSJMTFxSEhIUHpUKgScHFxgYeHR6UvlkZERFTRKJp016xZE59//jnq1asHAAgLC8PgwYNx7tw5NGnSpED76Oho9O/fH5MnT8b69evx66+/Yvr06ahevTqef/55AMDJkycxatQoLFiwAEOHDsW2bdswcuRIHD9+HO3bty/Xz0dEpk1OuN3c3GBnZ8dkiMqEJEl48uQJ4uPjAQCenp4KR0RERESGpJIkSVI6iLxcXV3xxRdfYOLEiQWee+edd7Bz505cvXpVvW/atGk4f/48Tp48CQAYNWoUkpKS8PPPP6vb9OvXD1WqVEF4eHiRYkhKSoKzszMSExM5JQlRJZWTk4O//voLbm5uqFq1qtLhUCXw8OFDxMfH45lnnikw1JznJYHfAxERGZOinpeMppBaTk4ONm3ahNTUVPj7++tsc/LkSfTp00drX9++fXHmzBn1/Zb62pw4caJsAieiCkn+m2JnZ6dwJFRZyP+tsX4AERFRxaJ4IbWLFy/C398f6enpcHBwwLZt29C4cWOdbePi4uDu7q61z93dHdnZ2Xjw4AE8PT31tomLi9MbQ0ZGBjIyMtTbSUlJpfhERFSRcEg5lRf+t0ZERFQxKd7T3aBBA0RFReHUqVN49dVXMW7cOFy5ckVv+/w/SuTR8Xn362pT2I+Z4OBgODs7qxdv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",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fig,ax = plt.subplots(1,2,figsize=(10,5))\n",
    "\n",
    "\n",
    "\n",
    "ax[0].plot(ticks,[alphas_CI[i][0] for i in range(len(ticks))],color='blue',marker='.',markersize=7)\n",
    "\n",
    "ax[0].plot(ticks,[alphas_CI[i][1] for i in range(len(ticks))],color='blue',marker='.',markersize=7,label='CI bounds')\n",
    "ax[0].fill_between(ticks,[alphas_CI[i][0] for i in range(len(ticks))],[alphas_CI[i][1] for i in range(len(ticks))],color='blue',alpha=0.1)\n",
    "ax[0].plot(ticks,alpha*np.ones(len(ticks)),color='red',ls='--',label='true parameter')\n",
    "ax[0].ticklabel_format(style='sci', axis='x', scilimits=(0, 0))\n",
    "ax[0].set_ylabel('Shape')\n",
    "ax[0].set_xlabel('Sample size')\n",
    "\n",
    "\n",
    "ax[1].plot(ticks,[betas_CI[i][0] for i in range(len(ticks))],color='blue',marker='.',markersize=7)\n",
    "ax[1].plot(ticks,[betas_CI[i][1] for i in range(len(ticks))],color='blue',marker='.',markersize=7)\n",
    "\n",
    "\n",
    "ax[1].fill_between(ticks,[betas_CI[i][0] for i in range(len(ticks))],[betas_CI[i][1] for i in range(len(ticks))],color='blue',alpha=0.1)\n",
    "ax[1].plot(ticks,beta*np.ones(len(ticks)),color='red',ls='--',label='True parameter')\n",
    "ax[1].ticklabel_format(style='sci', axis='x', scilimits=(0, 0))\n",
    "ax[0].legend()\n",
    "ax[1].set_ylabel('Rate')\n",
    "\n",
    "ax[1].set_xlabel('Sample size')\n",
    "fig.suptitle('Asymptotic behaviour of CI')\n",
    "fig.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import gamma\n",
    "from scipy.stats import norm\n",
    "\n",
    "\n",
    "NUMBER_PATHS = 50\n",
    "alpha =2\n",
    "beta=1\n",
    "data_paths_pre = np.random.gamma(alpha,scale=1/beta,size=(100,NUMBER_PATHS))\n",
    "data_paths_post = np.random.gamma(alpha,scale=1/(beta+10),size=(100,NUMBER_PATHS))\n",
    "\n",
    "data_paths = np.vstack((data_paths_pre,data_paths_post))\n",
    "p = 0.95\n",
    "\n",
    "# Function to compute CI for cumulative sum at each step\n",
    "def gamma_conf_interval(step, a, b, confidence=0.95):\n",
    "    alpha = step * a\n",
    "    lower_bound = gamma.ppf((1 - confidence) / 2, alpha, scale=b)\n",
    "    upper_bound = gamma.ppf(1 - (1 - confidence) / 2, alpha, scale=b)\n",
    "    return lower_bound, upper_bound\n",
    "\n",
    "BOUNDS =[gamma_conf_interval(t,alpha,1/beta,confidence=p) for t in range(200)]\n",
    "\n",
    "\n",
    "\n",
    "def estimate_parameter_CI(X,p):\n",
    "    alpha_hat, beta_hat = mom_estimates(X)\n",
    "    n= len(X)\n",
    "    var_alpha_hat = (6* alpha_hat**2) / n  #+ beta_hat**4*var_X\n",
    "    var_beta_hat = beta_hat**2/(n*alpha_hat) + beta_hat**6/alpha_hat**2*(2*alpha_hat**2)/beta_hat**4/n\n",
    "\n",
    "    # Confidence level (e.g., 95%)\n",
    "    confidence_level = p\n",
    "    z_alpha_2 = norm.ppf(1 - (1 - confidence_level) / 2)  # Critical value for normal distribution\n",
    "\n",
    "    # Confidence intervals\n",
    "    alpha_CI = (alpha_hat - z_alpha_2 * np.sqrt(var_alpha_hat), alpha_hat + z_alpha_2 * np.sqrt(var_alpha_hat))\n",
    "    beta_CI = (beta_hat - z_alpha_2 * np.sqrt(var_beta_hat), beta_hat + z_alpha_2 * np.sqrt(var_beta_hat))\n",
    "\n",
    "    return alpha_CI,beta_CI"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "alpha_lower, beta_lower = alphas_CI[-1][0],betas_CI[-1][0]\n",
    "alpha_upper, beta_upper = alphas_CI[-1][1],betas_CI[-1][1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [],
   "source": [
    "BOUNDS_beta_MoM = {'Lower':[gamma_conf_interval(t,alpha_lower,1/beta_lower,confidence=p) for t in range(200)],'Upper':[gamma_conf_interval(t,alpha_upper,1/beta_upper,confidence=p) for t in range(200)]}"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch",
   "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
