{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "053b586c",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1cbcca27",
   "metadata": {},
   "outputs": [],
   "source": [
    "from experiment_implementations import normal_normal_exp, beta_bern_exp\n",
    "from model_abstractions import KSAlg, CVMAlg, DiffMeans\n",
    "from submission_functions import identity_func, fabricated_spacing, fabricated_trimmed, add_coin_flips, add_bern_samples"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9672c999",
   "metadata": {},
   "source": [
    "# Do all the bern experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "fe44d32e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=2600729663\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:28<00:00, 3930.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=3112283277\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:37<00:00, 3867.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=543000172\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:37<00:00, 3863.17it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=2149593912\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:01<00:00, 4150.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=2718764412\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:12<00:00, 4057.27it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=2185879160\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:10<00:00, 4079.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=276922025\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [1:14:56<00:00, 444.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=3341372905\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [29:58<00:00, 1111.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=933080386\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [29:55<00:00, 1114.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=2298484528\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:29<00:00, 3926.34it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=3203259112\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:39<00:00, 3852.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=1457286780\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:40<00:00, 3841.87it/s]\n"
     ]
    }
   ],
   "source": [
    "alpha, beta = 2, 2\n",
    "runs =2000000\n",
    "num_data_per_agent = 5\n",
    "\n",
    "alg_dict = {'BCvM':None,\n",
    "            'KS':KSAlg(),\n",
    "            'CvM':CVMAlg(),\n",
    "            'Mean-Diff':DiffMeans()\n",
    "            }\n",
    "\n",
    "fts = {'truthful':identity_func,\n",
    "           'coin-flip':add_coin_flips,\n",
    "           'ber-samples':add_bern_samples}\n",
    "\n",
    "Ber_Results = []\n",
    "for al in alg_dict.keys():\n",
    "    for ft in fts.keys():\n",
    "        sub_funcs = [identity_func for _ in range(4)] + [fts[ft]]\n",
    "        results = beta_bern_exp(alpha=alpha,\n",
    "                                beta=beta,\n",
    "                                submission_funcs=sub_funcs,\n",
    "                                runs=runs,\n",
    "                                num_data_per_agent=num_data_per_agent,\n",
    "                                alg=alg_dict[al])\n",
    "        Ber_Results.append([f'{al} {ft}', results])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "3ce99f17",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BCvM truthful (array([0.01528689, 0.01526237, 0.01524795, 0.01522904, 0.01529348]), array([0.00105543, 0.00105609, 0.00104927, 0.00104876, 0.00105987]))\n",
      "BCvM coin-flip (array([0.0142656 , 0.01428515, 0.01427165, 0.01429293, 0.01647034]), array([0.00094818, 0.00095341, 0.00095062, 0.00095301, 0.0011753 ]))\n",
      "BCvM ber-samples (array([0.01534314, 0.01539646, 0.01536784, 0.01538545, 0.01598658]), array([0.00106002, 0.00106784, 0.0010581 , 0.00106596, 0.00120878]))\n",
      "KS truthful (array([0.17711697, 0.17709247, 0.17698042, 0.17708975, 0.17710457]), array([0.0186602 , 0.01869414, 0.01863027, 0.01865522, 0.01865502]))\n",
      "KS coin-flip (array([0.17827472, 0.1782774 , 0.17831516, 0.17842885, 0.17078117]), array([0.01796378, 0.0179474 , 0.01799529, 0.01793206, 0.01699878]))\n",
      "KS ber-samples (array([0.17868271, 0.17838927, 0.1784361 , 0.17864413, 0.18649913]), array([0.01856885, 0.01852567, 0.01855451, 0.01857814, 0.01969462]))\n",
      "CvM truthful (array([2.08031002, 2.08000505, 2.07978705, 2.0797609 , 2.08001283]), array([0.8453125 , 0.84552147, 0.84454974, 0.84420617, 0.84694775]))\n",
      "CvM coin-flip (array([2.25167638, 2.25181418, 2.2514508 , 2.25179809, 1.61292025]), array([0.90416345, 0.90352847, 0.9040864 , 0.90464803, 0.5391616 ]))\n",
      "CvM ber-samples (array([2.34425223, 2.34465245, 2.34489815, 2.34451688, 1.60658069]), array([1.07908946, 1.07948644, 1.07984045, 1.08022496, 0.50428977]))\n",
      "Mean-Diff truthful (array([0.1770472 , 0.17703792, 0.1768327 , 0.17688957, 0.17680595]), array([0.01862924, 0.01866072, 0.01863936, 0.0186328 , 0.01865097]))\n",
      "Mean-Diff coin-flip (array([0.1784075 , 0.17828579, 0.1781604 , 0.17832669, 0.17059234]), array([0.01797124, 0.01791729, 0.01795847, 0.01794805, 0.01695242]))\n",
      "Mean-Diff ber-samples (array([0.17859021, 0.17842409, 0.17841236, 0.17853557, 0.18656437]), array([0.01854774, 0.01853265, 0.01854505, 0.0185649 , 0.0197115 ]))\n"
     ]
    }
   ],
   "source": [
    "for t,r in Ber_Results:\n",
    "    print(t, r)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9182b832",
   "metadata": {},
   "source": [
    "# Do all the normal exps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7d5522a2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=1295675597\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:31<00:00, 3909.55it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=3767547439\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:32<00:00, 3901.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=3436981733\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:06<00:00, 4114.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=2218463666\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:06<00:00, 4112.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=4144641728\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [1:15:42<00:00, 440.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=1632426770\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [1:24:09<00:00, 396.08it/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=508546406\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:26<00:00, 3948.13it/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[run_experiment] No seed specified → using base_seed=2967939938\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000000/2000000 [08:23<00:00, 3972.86it/s] \n"
     ]
    }
   ],
   "source": [
    "prior_mean, prior_var = 0, 1\n",
    "var = 0.5\n",
    "runs = 2000000\n",
    "num_data_per_agent = 5\n",
    "\n",
    "alg_dict = {'BCvM':None,\n",
    "            'KS':KSAlg(),\n",
    "            'CvM':CVMAlg(),\n",
    "            'Mean-Diff':DiffMeans()}\n",
    "\n",
    "fts = {'truthful':identity_func,\n",
    "        'points-between':fabricated_spacing}\n",
    "\n",
    "Norm_Results = []\n",
    "for al in alg_dict.keys():\n",
    "    for ft in fts.keys():\n",
    "        sub_funcs = [identity_func for _ in range(4)] + [fts[ft]]\n",
    "        results = normal_normal_exp(prior_mean=prior_mean,\n",
    "                                     prior_var=prior_var,\n",
    "                                     var=var,\n",
    "                                    submission_funcs=sub_funcs,\n",
    "                                    runs=runs,\n",
    "                                    num_data_per_agent=num_data_per_agent,\n",
    "                                    alg=alg_dict[al])\n",
    "        Norm_Results.append([f'{al} {ft}', results])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "17c47234",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BCvM truthful (array([0.02257918, 0.02257401, 0.02259268, 0.02259176, 0.02255967]), array([0.00120799, 0.0012063 , 0.00120796, 0.00120714, 0.00120608]))\n",
      "BCvM points-between (array([0.02430207, 0.0242297 , 0.02431117, 0.02425062, 0.02329862]), array([0.00135388, 0.00134575, 0.00135316, 0.00134594, 0.00137341]))\n",
      "KS truthful (array([0.39006595, 0.39018645, 0.39010593, 0.3899991 , 0.39004503]), array([0.01531522, 0.01536354, 0.01532211, 0.01532021, 0.01533517]))\n",
      "KS points-between (array([0.39629149, 0.39601662, 0.39601613, 0.39607765, 0.3761622 ]), array([0.01612323, 0.01610595, 0.01605997, 0.0161044 , 0.01727543]))\n",
      "CvM truthful (array([0.17321384, 0.1733749 , 0.17326376, 0.17333114, 0.17335579]), array([0.01968005, 0.01970349, 0.01967104, 0.01970186, 0.01973912]))\n",
      "CvM points-between (array([0.18550672, 0.18573275, 0.18564289, 0.18544519, 0.27384585]), array([0.02377322, 0.02381893, 0.02376376, 0.02373884, 0.05905502]))\n",
      "Mean-Diff truthful (array([0.28212851, 0.28211224, 0.28205614, 0.28206171, 0.2817001 ]), array([0.04541971, 0.04539814, 0.04541156, 0.04541522, 0.04540743]))\n",
      "Mean-Diff points-between (array([0.28470405, 0.28461257, 0.28474751, 0.28463297, 0.28427602]), array([0.04626417, 0.04621057, 0.04626002, 0.0462162 , 0.04612972]))\n"
     ]
    }
   ],
   "source": [
    "for t,r in Norm_Results:\n",
    "    print(t, r)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dai",
   "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.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
