{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import random\n",
    "import numpy as np\n",
    "import scipy.stats as stats\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import math\n",
    "sns.set_style({'font.family':'serif', 'font.serif':'Times New Roman'})"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Get Data In "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>paper</th>\n",
       "      <th>ratings</th>\n",
       "      <th>decisions</th>\n",
       "      <th>average_score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3015</th>\n",
       "      <td>Pitfalls of In-Domain Uncertainty Estimation a...</td>\n",
       "      <td>6;8;6</td>\n",
       "      <td>1</td>\n",
       "      <td>6.7</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3016</th>\n",
       "      <td>A Theory of Usable Information under Computati...</td>\n",
       "      <td>8;8</td>\n",
       "      <td>1</td>\n",
       "      <td>8.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3017</th>\n",
       "      <td>An Inductive Bias for Distances: Neural Nets t...</td>\n",
       "      <td>8;3;8;8</td>\n",
       "      <td>1</td>\n",
       "      <td>6.8</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                  paper  ratings  decisions  \\\n",
       "3015  Pitfalls of In-Domain Uncertainty Estimation a...    6;8;6          1   \n",
       "3016  A Theory of Usable Information under Computati...      8;8          1   \n",
       "3017  An Inductive Bias for Distances: Neural Nets t...  8;3;8;8          1   \n",
       "\n",
       "      average_score  \n",
       "3015            6.7  \n",
       "3016            8.0  \n",
       "3017            6.8  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.read_csv(\"../dataset_final.csv\", quotechar = '\"')\n",
    "\n",
    "def clean_decision(row):\n",
    "    if \"Reject\" == row['decisions'] or \"Invite to Workshop Track\" == row['decisions'] or \"Withdrawn\" == row['decisions']:\n",
    "        return 0\n",
    "    return 1\n",
    "\n",
    "def calculate_average_score(row):\n",
    "    ratings = [float(rating) for rating in row['ratings'].split(\";\")]\n",
    "    return round(sum(ratings) / len(ratings), 1)\n",
    "\n",
    "data = dict()\n",
    "\n",
    "for year in range(2017, 2021):\n",
    "    data[year] = df[df.year==year][['paper', 'ratings', 'decisions']].copy()\n",
    "    data[year]['average_score'] = data[year].apply(calculate_average_score, axis = 1)\n",
    "    data[year]['decisions'] = data[year].apply(clean_decision, axis = 1)\n",
    "    \n",
    "data[2020].head(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Using Logistic Regression to Predict Probability of a Paper Being Accepted Given Score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "\n",
    "def get_model(data, xlabel=\"average_score\", ylabel=\"decisions\"):\n",
    "    \"\"\"Returns fitted logistic regression model on data\"\"\"\n",
    "    X, y = np.array(data[xlabel]).reshape(-1, 1), np.array(data[ylabel])\n",
    "    X_train, X_test, y_train, y_test = train_test_split(X, y, test_size = 1, random_state = 0)\n",
    "    LogReg = LogisticRegression()\n",
    "    LogReg.fit(X_train, y_train)\n",
    "    return LogReg\n",
    "\n",
    "def accept_proba(model, score):\n",
    "    \"\"\"Returns the probability of a paper being accepted given score\"\"\"\n",
    "    return model.predict_proba([[score]])[0][1]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### ANOVA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_ratings_lst(df):\n",
    "    \"\"\"Returns a list of lists of paper ratings in numeric format. Assumes ratings exist\"\"\"\n",
    "    lst = []\n",
    "    \n",
    "    for row in df.iterrows():\n",
    "        if not isinstance(row[1]['ratings'], str):\n",
    "            continue\n",
    "            \n",
    "        ratings = []\n",
    "        for rating in row[1]['ratings'].split(\";\"):\n",
    "            ratings.append(int(rating))\n",
    "            \n",
    "        lst.append(ratings)\n",
    "        \n",
    "    return lst\n",
    "\n",
    "def get_mean_between(lst_of_lsts):\n",
    "    \"\"\"Returns the mean of all list averages\"\"\"\n",
    "    total = 0\n",
    "    for lst in lst_of_lsts:\n",
    "        total += sum(lst) / len(lst)\n",
    "    return total / len(lst_of_lsts)\n",
    "\n",
    "def get_mean_total(lst_of_lsts):\n",
    "    \"\"\"Returns the mean of all number in list of lists\"\"\"\n",
    "    total = 0\n",
    "    count = 0\n",
    "    for lst in lst_of_lsts:\n",
    "        for num in lst:\n",
    "            total += num\n",
    "            count += 1\n",
    "    return total / count\n",
    "\n",
    "\n",
    "def get_variance_between(lst_of_lsts):\n",
    "    \"\"\"Returns the mean variance between groups. MSB = SSB / degree of freedom\"\"\"\n",
    "    ssb = 0\n",
    "    mean = get_mean_total(lst_of_lsts)\n",
    "    \n",
    "    for lst in lst_of_lsts:\n",
    "        mean_within = sum(lst) / len(lst)\n",
    "        var = len(lst) * (mean_within - mean) ** 2\n",
    "        ssb += var\n",
    "        \n",
    "    degree_of_freedom = len(lst_of_lsts) - 1\n",
    "    return ssb / degree_of_freedom\n",
    "\n",
    "def get_variance_within(lst_of_lsts):\n",
    "    \"\"\"Returns the mean variance within a group. MSW = SSW / degree of freedom\"\"\"\n",
    "    if len(lst_of_lsts) == 0:\n",
    "        return np.nan\n",
    "    \n",
    "    ssw = 0\n",
    "    total_reviews = 0\n",
    "    \n",
    "    for lst in lst_of_lsts:\n",
    "        mean_within = sum(lst) / len(lst)\n",
    "        var = 0\n",
    "        for num in lst:\n",
    "            var += (num - mean_within) ** 2\n",
    "        ssw += var\n",
    "        total_reviews += len(lst)\n",
    "    \n",
    "    groups = len(lst_of_lsts)\n",
    "    degree_of_freedom = total_reviews - groups\n",
    "    return ssw / degree_of_freedom\n",
    "\n",
    "\n",
    "def anova_with_lm(data, n, low, high, acceptance_bar=0, iters=1000):\n",
    "    decision_model = get_model(data)\n",
    "    \n",
    "    lst_of_lsts = get_ratings_lst(data)\n",
    "    std_within = get_variance_within(lst_of_lsts) ** 0.5\n",
    "    \n",
    "    def generate_decisions(true_scores):\n",
    "        papers_reviews = []\n",
    "\n",
    "        for true_score in true_scores:\n",
    "            mu, sigma = true_score, std_within\n",
    "            paper_reviews = stats.truncnorm((low - mu) / sigma, (high - mu) / sigma, loc=mu, scale=sigma).rvs(n)\n",
    "            papers_reviews.append(paper_reviews)\n",
    "        \n",
    "        decisions = []\n",
    "        for paper_reviews in papers_reviews:\n",
    "            average_score = sum(paper_reviews) / len(paper_reviews)\n",
    "            if np.random.random() < accept_proba(decision_model, average_score) + acceptance_bar:\n",
    "                decisions.append(1)\n",
    "            else:\n",
    "                decisions.append(0)\n",
    "\n",
    "        return decisions\n",
    "    \n",
    "    mu = get_mean_between(lst_of_lsts)\n",
    "    sigma = get_variance_between(lst_of_lsts) ** 0.5\n",
    "    total = len(lst_of_lsts)\n",
    "    \n",
    "    bt = []\n",
    "    \n",
    "    for i in range(iters):\n",
    "        accept_again = 0\n",
    "        accept_first = 0\n",
    "        true_scores = stats.truncnorm((low - mu) / sigma, (high - mu) / sigma, loc=mu, scale=sigma).rvs(total)\n",
    "        first_decisions = generate_decisions(true_scores)\n",
    "        second_decisions = generate_decisions(true_scores)\n",
    "        for first, second in zip(first_decisions, second_decisions):\n",
    "            accept_again += 1 if first == 1 and second == 1 else 0\n",
    "            accept_first += 1 if first == 1 else 0\n",
    "        bt.append(accept_again / accept_first)\n",
    "        print(i)\n",
    "        \n",
    "    return bt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Year\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n",
      "20\n",
      "21\n",
      "22\n",
      "23\n",
      "24\n",
      "25\n",
      "26\n",
      "27\n",
      "28\n",
      "29\n",
      "30\n",
      "31\n",
      "32\n",
      "33\n",
      "34\n",
      "35\n",
      "36\n",
      "37\n",
      "38\n",
      "39\n",
      "40\n",
      "41\n",
      "42\n",
      "43\n",
      "44\n",
      "45\n",
      "46\n",
      "47\n",
      "48\n",
      "49\n",
      "50\n",
      "51\n",
      "52\n",
      "53\n",
      "54\n",
      "55\n",
      "56\n",
      "57\n",
      "58\n",
      "59\n",
      "60\n",
      "61\n",
      "62\n",
      "63\n",
      "64\n",
      "65\n",
      "66\n",
      "67\n",
      "68\n",
      "69\n",
      "70\n",
      "71\n",
      "72\n",
      "73\n",
      "74\n",
      "75\n",
      "76\n",
      "77\n",
      "78\n",
      "79\n",
      "80\n",
      "81\n",
      "82\n",
      "83\n",
      "84\n",
      "85\n",
      "86\n",
      "87\n",
      "88\n",
      "89\n",
      "90\n",
      "91\n",
      "92\n",
      "93\n",
      "94\n",
      "95\n",
      "96\n",
      "97\n",
      "98\n",
      "99\n",
      "100\n",
      "101\n",
      "102\n",
      "103\n",
      "104\n",
      "105\n",
      "106\n",
      "107\n",
      "108\n",
      "109\n",
      "110\n",
      "111\n",
      "112\n",
      "113\n",
      "114\n",
      "115\n",
      "116\n",
      "117\n",
      "118\n",
      "119\n",
      "120\n",
      "121\n",
      "122\n",
      "123\n",
      "124\n",
      "125\n",
      "126\n",
      "127\n",
      "128\n",
      "129\n",
      "130\n",
      "131\n",
      "132\n",
      "133\n",
      "134\n",
      "135\n",
      "136\n",
      "137\n",
      "138\n",
      "139\n",
      "140\n",
      "141\n",
      "142\n",
      "143\n",
      "144\n",
      "145\n",
      "146\n",
      "147\n",
      "148\n",
      "149\n",
      "150\n",
      "151\n",
      "152\n",
      "153\n",
      "154\n",
      "155\n",
      "156\n",
      "157\n",
      "158\n",
      "159\n",
      "160\n",
      "161\n",
      "162\n",
      "163\n",
      "164\n",
      "165\n",
      "166\n",
      "167\n",
      "168\n",
      "169\n",
      "170\n",
      "171\n",
      "172\n",
      "173\n",
      "174\n",
      "175\n",
      "176\n",
      "177\n",
      "178\n",
      "179\n",
      "180\n",
      "181\n",
      "182\n",
      "183\n",
      "184\n",
      "185\n",
      "186\n",
      "187\n",
      "188\n",
      "189\n",
      "190\n",
      "191\n",
      "192\n",
      "193\n",
      "194\n",
      "195\n",
      "196\n",
      "197\n",
      "198\n",
      "199\n",
      "200\n",
      "201\n",
      "202\n",
      "203\n",
      "204\n",
      "205\n",
      "206\n",
      "207\n",
      "208\n",
      "209\n",
      "210\n",
      "211\n",
      "212\n",
      "213\n",
      "214\n",
      "215\n",
      "216\n",
      "217\n",
      "218\n",
      "219\n",
      "220\n",
      "221\n",
      "222\n",
      "223\n",
      "224\n",
      "225\n",
      "226\n",
      "227\n",
      "228\n",
      "229\n",
      "230\n",
      "231\n",
      "232\n",
      "233\n",
      "234\n",
      "235\n",
      "236\n",
      "237\n",
      "238\n",
      "239\n",
      "240\n",
      "241\n",
      "242\n",
      "243\n",
      "244\n",
      "245\n",
      "246\n",
      "247\n",
      "248\n",
      "249\n",
      "250\n",
      "251\n",
      "252\n",
      "253\n",
      "254\n",
      "255\n",
      "256\n",
      "257\n",
      "258\n",
      "259\n",
      "260\n",
      "261\n",
      "262\n",
      "263\n",
      "264\n",
      "265\n",
      "266\n",
      "267\n",
      "268\n",
      "269\n",
      "270\n",
      "271\n",
      "272\n",
      "273\n",
      "274\n",
      "275\n",
      "276\n",
      "277\n",
      "278\n",
      "279\n",
      "280\n",
      "281\n",
      "282\n",
      "283\n",
      "284\n",
      "285\n",
      "286\n",
      "287\n",
      "288\n",
      "289\n",
      "290\n",
      "291\n",
      "292\n",
      "293\n",
      "294\n",
      "295\n",
      "296\n",
      "297\n",
      "298\n",
      "299\n",
      "300\n",
      "301\n",
      "302\n",
      "303\n",
      "304\n",
      "305\n",
      "306\n",
      "307\n",
      "308\n",
      "309\n",
      "310\n",
      "311\n",
      "312\n",
      "313\n",
      "314\n",
      "315\n",
      "316\n",
      "317\n",
      "318\n",
      "319\n",
      "320\n",
      "321\n",
      "322\n",
      "323\n",
      "324\n",
      "325\n",
      "326\n",
      "327\n",
      "328\n",
      "329\n",
      "330\n",
      "331\n",
      "332\n",
      "333\n",
      "334\n",
      "335\n",
      "336\n",
      "337\n",
      "338\n",
      "339\n",
      "340\n",
      "341\n",
      "342\n",
      "343\n",
      "344\n",
      "345\n",
      "346\n",
      "347\n",
      "348\n",
      "349\n",
      "350\n",
      "351\n",
      "352\n",
      "353\n",
      "354\n",
      "355\n",
      "356\n",
      "357\n",
      "358\n",
      "359\n",
      "360\n",
      "361\n",
      "362\n",
      "363\n",
      "364\n",
      "365\n",
      "366\n",
      "367\n",
      "368\n",
      "369\n",
      "370\n",
      "371\n",
      "372\n",
      "373\n",
      "374\n",
      "375\n",
      "376\n",
      "377\n",
      "378\n",
      "379\n",
      "380\n",
      "381\n",
      "382\n",
      "383\n",
      "384\n",
      "385\n",
      "386\n",
      "387\n",
      "388\n",
      "389\n",
      "390\n",
      "391\n",
      "392\n",
      "393\n",
      "394\n",
      "395\n",
      "396\n",
      "397\n",
      "398\n",
      "399\n",
      "400\n",
      "401\n",
      "402\n",
      "403\n",
      "404\n",
      "405\n",
      "406\n",
      "407\n",
      "408\n",
      "409\n",
      "410\n",
      "411\n",
      "412\n",
      "413\n",
      "414\n",
      "415\n",
      "416\n",
      "417\n",
      "418\n",
      "419\n",
      "420\n",
      "421\n",
      "422\n",
      "423\n",
      "424\n",
      "425\n",
      "426\n",
      "427\n",
      "428\n",
      "429\n",
      "430\n",
      "431\n",
      "432\n",
      "433\n",
      "434\n",
      "435\n",
      "436\n",
      "437\n",
      "438\n",
      "439\n",
      "440\n",
      "441\n",
      "442\n",
      "443\n",
      "444\n",
      "445\n",
      "446\n",
      "447\n",
      "448\n",
      "449\n",
      "450\n",
      "451\n",
      "452\n",
      "453\n",
      "454\n",
      "455\n",
      "456\n",
      "457\n",
      "458\n",
      "459\n",
      "460\n",
      "461\n",
      "462\n",
      "463\n",
      "464\n",
      "465\n",
      "466\n",
      "467\n",
      "468\n",
      "469\n",
      "470\n",
      "471\n",
      "472\n",
      "473\n",
      "474\n",
      "475\n",
      "476\n",
      "477\n",
      "478\n",
      "479\n",
      "480\n",
      "481\n",
      "482\n",
      "483\n",
      "484\n",
      "485\n",
      "486\n",
      "487\n",
      "488\n",
      "489\n",
      "490\n",
      "491\n",
      "492\n",
      "493\n",
      "494\n",
      "495\n",
      "496\n",
      "497\n",
      "498\n",
      "499\n",
      "500\n",
      "501\n",
      "502\n",
      "503\n",
      "504\n",
      "505\n",
      "506\n",
      "507\n",
      "508\n",
      "509\n",
      "510\n",
      "511\n",
      "512\n",
      "513\n",
      "514\n",
      "515\n",
      "516\n",
      "517\n",
      "518\n",
      "519\n",
      "520\n",
      "521\n",
      "522\n",
      "523\n",
      "524\n",
      "525\n",
      "526\n",
      "527\n",
      "528\n",
      "529\n",
      "530\n",
      "531\n",
      "532\n",
      "533\n",
      "534\n",
      "535\n",
      "536\n",
      "537\n",
      "538\n",
      "539\n",
      "540\n",
      "541\n",
      "542\n",
      "543\n",
      "544\n",
      "545\n",
      "546\n",
      "547\n",
      "548\n",
      "549\n",
      "550\n",
      "551\n",
      "552\n",
      "553\n",
      "554\n",
      "555\n",
      "556\n",
      "557\n",
      "558\n",
      "559\n",
      "560\n",
      "561\n",
      "562\n",
      "563\n",
      "564\n",
      "565\n",
      "566\n",
      "567\n",
      "568\n",
      "569\n",
      "570\n",
      "571\n",
      "572\n",
      "573\n",
      "574\n",
      "575\n",
      "576\n",
      "577\n",
      "578\n",
      "579\n",
      "580\n",
      "581\n",
      "582\n",
      "583\n",
      "584\n",
      "585\n",
      "586\n",
      "587\n",
      "588\n",
      "589\n",
      "590\n",
      "591\n",
      "592\n",
      "593\n",
      "594\n",
      "595\n",
      "596\n",
      "597\n",
      "598\n",
      "599\n",
      "600\n",
      "601\n",
      "602\n",
      "603\n",
      "604\n",
      "605\n",
      "606\n",
      "607\n",
      "608\n",
      "609\n",
      "610\n",
      "611\n",
      "612\n",
      "613\n",
      "614\n",
      "615\n",
      "616\n",
      "617\n",
      "618\n",
      "619\n",
      "620\n",
      "621\n",
      "622\n",
      "623\n",
      "624\n",
      "625\n",
      "626\n",
      "627\n",
      "628\n",
      "629\n",
      "630\n",
      "631\n",
      "632\n",
      "633\n",
      "634\n",
      "635\n",
      "636\n",
      "637\n",
      "638\n",
      "639\n",
      "640\n",
      "641\n",
      "642\n",
      "643\n",
      "644\n",
      "645\n",
      "646\n",
      "647\n",
      "648\n",
      "649\n",
      "650\n",
      "651\n",
      "652\n",
      "653\n",
      "654\n",
      "655\n",
      "656\n",
      "657\n",
      "658\n",
      "659\n",
      "660\n",
      "661\n",
      "662\n",
      "663\n",
      "664\n",
      "665\n",
      "666\n",
      "667\n",
      "668\n",
      "669\n",
      "670\n",
      "671\n",
      "672\n",
      "673\n",
      "674\n",
      "675\n",
      "676\n",
      "677\n",
      "678\n",
      "679\n",
      "680\n",
      "681\n",
      "682\n",
      "683\n",
      "684\n",
      "685\n",
      "686\n",
      "687\n",
      "688\n",
      "689\n",
      "690\n",
      "691\n",
      "692\n",
      "693\n",
      "694\n",
      "695\n",
      "696\n",
      "697\n",
      "698\n",
      "699\n",
      "700\n",
      "701\n",
      "702\n",
      "703\n",
      "704\n",
      "705\n",
      "706\n",
      "707\n",
      "708\n",
      "709\n",
      "710\n",
      "711\n",
      "712\n",
      "713\n",
      "714\n",
      "715\n",
      "716\n",
      "717\n",
      "718\n",
      "719\n",
      "720\n",
      "721\n",
      "722\n",
      "723\n",
      "724\n",
      "725\n",
      "726\n",
      "727\n",
      "728\n",
      "729\n",
      "730\n",
      "731\n",
      "732\n",
      "733\n",
      "734\n",
      "735\n",
      "736\n",
      "737\n",
      "738\n",
      "739\n",
      "740\n",
      "741\n",
      "742\n",
      "743\n",
      "744\n",
      "745\n",
      "746\n",
      "747\n",
      "748\n",
      "749\n",
      "750\n",
      "751\n",
      "752\n",
      "753\n",
      "754\n",
      "755\n",
      "756\n",
      "757\n",
      "758\n",
      "759\n",
      "760\n",
      "761\n",
      "762\n",
      "763\n",
      "764\n",
      "765\n",
      "766\n",
      "767\n",
      "768\n",
      "769\n",
      "770\n",
      "771\n",
      "772\n",
      "773\n",
      "774\n",
      "775\n",
      "776\n",
      "777\n",
      "778\n",
      "779\n",
      "780\n",
      "781\n",
      "782\n",
      "783\n",
      "784\n",
      "785\n",
      "786\n",
      "787\n",
      "788\n",
      "789\n",
      "790\n",
      "791\n",
      "792\n",
      "793\n",
      "794\n",
      "795\n",
      "796\n",
      "797\n",
      "798\n",
      "799\n",
      "800\n",
      "801\n",
      "802\n",
      "803\n",
      "804\n",
      "805\n",
      "806\n",
      "807\n",
      "808\n",
      "809\n",
      "810\n",
      "811\n",
      "812\n",
      "813\n",
      "814\n",
      "815\n",
      "816\n",
      "817\n",
      "818\n",
      "819\n",
      "820\n",
      "821\n",
      "822\n",
      "823\n",
      "824\n",
      "825\n",
      "826\n",
      "827\n",
      "828\n",
      "829\n",
      "830\n",
      "831\n",
      "832\n",
      "833\n",
      "834\n",
      "835\n",
      "836\n",
      "837\n",
      "838\n",
      "839\n",
      "840\n",
      "841\n",
      "842\n",
      "843\n",
      "844\n",
      "845\n",
      "846\n",
      "847\n",
      "848\n",
      "849\n",
      "850\n",
      "851\n",
      "852\n",
      "853\n",
      "854\n",
      "855\n",
      "856\n",
      "857\n",
      "858\n",
      "859\n",
      "860\n",
      "861\n",
      "862\n",
      "863\n",
      "864\n",
      "865\n",
      "866\n",
      "867\n",
      "868\n",
      "869\n",
      "870\n",
      "871\n",
      "872\n",
      "873\n",
      "874\n",
      "875\n",
      "876\n",
      "877\n",
      "878\n",
      "879\n",
      "880\n",
      "881\n",
      "882\n",
      "883\n",
      "884\n",
      "885\n",
      "886\n",
      "887\n",
      "888\n",
      "889\n",
      "890\n",
      "891\n",
      "892\n",
      "893\n",
      "894\n",
      "895\n",
      "896\n",
      "897\n",
      "898\n",
      "899\n",
      "900\n",
      "901\n",
      "902\n",
      "903\n",
      "904\n",
      "905\n",
      "906\n",
      "907\n",
      "908\n",
      "909\n",
      "910\n",
      "911\n",
      "912\n",
      "913\n",
      "914\n",
      "915\n",
      "916\n",
      "917\n",
      "918\n",
      "919\n",
      "920\n",
      "921\n",
      "922\n",
      "923\n",
      "924\n",
      "925\n",
      "926\n",
      "927\n",
      "928\n",
      "929\n",
      "930\n",
      "931\n",
      "932\n",
      "933\n",
      "934\n",
      "935\n",
      "936\n",
      "937\n",
      "938\n",
      "939\n",
      "940\n",
      "941\n",
      "942\n",
      "943\n",
      "944\n",
      "945\n",
      "946\n",
      "947\n",
      "948\n",
      "949\n",
      "950\n",
      "951\n",
      "952\n",
      "953\n",
      "954\n",
      "955\n",
      "956\n",
      "957\n",
      "958\n",
      "959\n",
      "960\n",
      "961\n",
      "962\n",
      "963\n",
      "964\n",
      "965\n",
      "966\n",
      "967\n",
      "968\n",
      "969\n",
      "970\n",
      "971\n",
      "972\n",
      "973\n",
      "974\n",
      "975\n",
      "976\n",
      "977\n",
      "978\n",
      "979\n",
      "980\n",
      "981\n",
      "982\n",
      "983\n",
      "984\n",
      "985\n",
      "986\n",
      "987\n",
      "988\n",
      "989\n",
      "990\n",
      "991\n",
      "992\n",
      "993\n",
      "994\n",
      "995\n",
      "996\n",
      "997\n",
      "998\n",
      "999\n",
      "1000\n",
      "1001\n",
      "1002\n",
      "1003\n",
      "1004\n",
      "1005\n",
      "1006\n",
      "1007\n",
      "1008\n",
      "1009\n",
      "1010\n",
      "1011\n",
      "1012\n",
      "1013\n",
      "1014\n",
      "1015\n",
      "1016\n",
      "1017\n",
      "1018\n",
      "1019\n",
      "1020\n",
      "1021\n",
      "1022\n",
      "1023\n",
      "1024\n",
      "1025\n",
      "1026\n",
      "1027\n",
      "1028\n",
      "1029\n",
      "1030\n",
      "1031\n",
      "1032\n",
      "1033\n",
      "1034\n",
      "1035\n",
      "1036\n",
      "1037\n",
      "1038\n",
      "1039\n",
      "1040\n",
      "1041\n",
      "1042\n",
      "1043\n",
      "1044\n",
      "1045\n",
      "1046\n",
      "1047\n",
      "1048\n",
      "1049\n",
      "1050\n",
      "1051\n",
      "1052\n",
      "1053\n",
      "1054\n",
      "1055\n",
      "1056\n",
      "1057\n",
      "1058\n",
      "1059\n",
      "1060\n",
      "1061\n",
      "1062\n",
      "1063\n",
      "1064\n",
      "1065\n",
      "1066\n",
      "1067\n",
      "1068\n",
      "1069\n",
      "1070\n",
      "1071\n",
      "1072\n",
      "1073\n",
      "1074\n",
      "1075\n",
      "1076\n",
      "1077\n",
      "1078\n",
      "1079\n",
      "1080\n",
      "1081\n",
      "1082\n",
      "1083\n",
      "1084\n",
      "1085\n",
      "1086\n",
      "1087\n",
      "1088\n",
      "1089\n",
      "1090\n",
      "1091\n",
      "1092\n",
      "1093\n",
      "1094\n",
      "1095\n",
      "1096\n",
      "1097\n",
      "1098\n",
      "1099\n",
      "1100\n",
      "1101\n",
      "1102\n",
      "1103\n",
      "1104\n",
      "1105\n",
      "1106\n",
      "1107\n",
      "1108\n",
      "1109\n",
      "1110\n",
      "1111\n",
      "1112\n",
      "1113\n",
      "1114\n",
      "1115\n",
      "1116\n",
      "1117\n",
      "1118\n",
      "1119\n",
      "1120\n",
      "1121\n",
      "1122\n",
      "1123\n",
      "1124\n",
      "1125\n",
      "1126\n",
      "1127\n",
      "1128\n",
      "1129\n",
      "1130\n",
      "1131\n",
      "1132\n",
      "1133\n",
      "1134\n",
      "1135\n",
      "1136\n",
      "1137\n",
      "1138\n",
      "1139\n",
      "1140\n",
      "1141\n",
      "1142\n",
      "1143\n",
      "1144\n",
      "1145\n",
      "1146\n",
      "1147\n",
      "1148\n",
      "1149\n",
      "1150\n",
      "1151\n",
      "1152\n",
      "1153\n",
      "1154\n",
      "1155\n",
      "1156\n",
      "1157\n",
      "1158\n",
      "1159\n",
      "1160\n",
      "1161\n",
      "1162\n",
      "1163\n",
      "1164\n",
      "1165\n",
      "1166\n",
      "1167\n",
      "1168\n",
      "1169\n",
      "1170\n",
      "1171\n",
      "1172\n",
      "1173\n",
      "1174\n",
      "1175\n",
      "1176\n",
      "1177\n",
      "1178\n",
      "1179\n",
      "1180\n",
      "1181\n",
      "1182\n",
      "1183\n",
      "1184\n",
      "1185\n",
      "1186\n",
      "1187\n",
      "1188\n",
      "1189\n",
      "1190\n",
      "1191\n",
      "1192\n",
      "1193\n",
      "1194\n",
      "1195\n",
      "1196\n",
      "1197\n",
      "1198\n",
      "1199\n",
      "1200\n",
      "1201\n",
      "1202\n",
      "1203\n",
      "1204\n",
      "1205\n",
      "1206\n",
      "1207\n",
      "1208\n",
      "1209\n",
      "1210\n",
      "1211\n",
      "1212\n",
      "1213\n",
      "1214\n",
      "1215\n",
      "1216\n",
      "1217\n",
      "1218\n",
      "1219\n",
      "1220\n",
      "1221\n",
      "1222\n",
      "1223\n",
      "1224\n",
      "1225\n",
      "1226\n",
      "1227\n",
      "1228\n",
      "1229\n",
      "1230\n",
      "1231\n",
      "1232\n",
      "1233\n",
      "1234\n",
      "1235\n",
      "1236\n",
      "1237\n",
      "1238\n",
      "1239\n",
      "1240\n",
      "1241\n",
      "1242\n",
      "1243\n",
      "1244\n",
      "1245\n",
      "1246\n",
      "1247\n",
      "1248\n",
      "1249\n",
      "1250\n",
      "1251\n",
      "1252\n",
      "1253\n",
      "1254\n",
      "1255\n",
      "1256\n",
      "1257\n",
      "1258\n",
      "1259\n",
      "1260\n",
      "1261\n",
      "1262\n",
      "1263\n",
      "1264\n",
      "1265\n",
      "1266\n",
      "1267\n",
      "1268\n",
      "1269\n",
      "1270\n",
      "1271\n",
      "1272\n",
      "1273\n",
      "1274\n",
      "1275\n",
      "1276\n",
      "1277\n",
      "1278\n",
      "1279\n",
      "1280\n",
      "1281\n",
      "1282\n",
      "1283\n",
      "1284\n",
      "1285\n",
      "1286\n",
      "1287\n",
      "1288\n",
      "1289\n",
      "1290\n",
      "1291\n",
      "1292\n",
      "1293\n",
      "1294\n",
      "1295\n",
      "1296\n",
      "1297\n",
      "1298\n",
      "1299\n",
      "1300\n",
      "1301\n",
      "1302\n",
      "1303\n",
      "1304\n",
      "1305\n",
      "1306\n",
      "1307\n",
      "1308\n",
      "1309\n",
      "1310\n",
      "1311\n",
      "1312\n",
      "1313\n",
      "1314\n",
      "1315\n",
      "1316\n",
      "1317\n",
      "1318\n",
      "1319\n",
      "1320\n",
      "1321\n",
      "1322\n",
      "1323\n",
      "1324\n",
      "1325\n",
      "1326\n",
      "1327\n",
      "1328\n",
      "1329\n",
      "1330\n",
      "1331\n",
      "1332\n",
      "1333\n",
      "1334\n",
      "1335\n",
      "1336\n",
      "1337\n",
      "1338\n",
      "1339\n",
      "1340\n",
      "1341\n",
      "1342\n",
      "1343\n",
      "1344\n",
      "1345\n",
      "1346\n",
      "1347\n",
      "1348\n",
      "1349\n",
      "1350\n",
      "1351\n",
      "1352\n",
      "1353\n",
      "1354\n",
      "1355\n",
      "1356\n",
      "1357\n",
      "1358\n",
      "1359\n",
      "1360\n",
      "1361\n",
      "1362\n",
      "1363\n",
      "1364\n",
      "1365\n",
      "1366\n",
      "1367\n",
      "1368\n",
      "1369\n",
      "1370\n",
      "1371\n",
      "1372\n",
      "1373\n",
      "1374\n",
      "1375\n",
      "1376\n",
      "1377\n",
      "1378\n",
      "1379\n",
      "1380\n",
      "1381\n",
      "1382\n",
      "1383\n",
      "1384\n",
      "1385\n",
      "1386\n",
      "1387\n",
      "1388\n",
      "1389\n",
      "1390\n",
      "1391\n",
      "1392\n",
      "1393\n",
      "1394\n",
      "1395\n",
      "1396\n",
      "1397\n",
      "1398\n",
      "1399\n",
      "1400\n",
      "1401\n",
      "1402\n",
      "1403\n",
      "1404\n",
      "1405\n",
      "1406\n",
      "1407\n",
      "1408\n",
      "1409\n",
      "1410\n",
      "1411\n",
      "1412\n",
      "1413\n",
      "1414\n",
      "1415\n",
      "1416\n",
      "1417\n",
      "1418\n",
      "1419\n",
      "1420\n",
      "1421\n",
      "1422\n",
      "1423\n",
      "1424\n",
      "1425\n",
      "1426\n",
      "1427\n",
      "1428\n",
      "1429\n",
      "1430\n",
      "1431\n",
      "1432\n",
      "1433\n",
      "1434\n",
      "1435\n",
      "1436\n",
      "1437\n",
      "1438\n",
      "1439\n",
      "1440\n",
      "1441\n",
      "1442\n",
      "1443\n",
      "1444\n",
      "1445\n",
      "1446\n",
      "1447\n",
      "1448\n",
      "1449\n",
      "1450\n",
      "1451\n",
      "1452\n",
      "1453\n",
      "1454\n",
      "1455\n",
      "1456\n",
      "1457\n",
      "1458\n",
      "1459\n",
      "1460\n",
      "1461\n",
      "1462\n",
      "1463\n",
      "1464\n",
      "1465\n",
      "1466\n",
      "1467\n",
      "1468\n",
      "1469\n",
      "1470\n",
      "1471\n",
      "1472\n",
      "1473\n",
      "1474\n",
      "1475\n",
      "1476\n",
      "1477\n",
      "1478\n",
      "1479\n",
      "1480\n",
      "1481\n",
      "1482\n",
      "1483\n",
      "1484\n",
      "1485\n",
      "1486\n",
      "1487\n",
      "1488\n",
      "1489\n",
      "1490\n",
      "1491\n",
      "1492\n",
      "1493\n",
      "1494\n",
      "1495\n",
      "1496\n",
      "1497\n",
      "1498\n",
      "1499\n",
      "1500\n",
      "1501\n",
      "1502\n",
      "1503\n",
      "1504\n",
      "1505\n",
      "1506\n",
      "1507\n",
      "1508\n",
      "1509\n",
      "1510\n",
      "1511\n",
      "1512\n",
      "1513\n",
      "1514\n",
      "1515\n",
      "1516\n",
      "1517\n",
      "1518\n",
      "1519\n",
      "1520\n",
      "1521\n",
      "1522\n",
      "1523\n",
      "1524\n",
      "1525\n",
      "1526\n",
      "1527\n",
      "1528\n",
      "1529\n",
      "1530\n",
      "1531\n",
      "1532\n",
      "1533\n",
      "1534\n",
      "1535\n",
      "1536\n",
      "1537\n",
      "1538\n",
      "1539\n",
      "1540\n",
      "1541\n",
      "1542\n",
      "1543\n",
      "1544\n",
      "1545\n",
      "1546\n",
      "1547\n",
      "1548\n",
      "1549\n",
      "1550\n",
      "1551\n",
      "1552\n",
      "1553\n",
      "1554\n",
      "1555\n",
      "1556\n",
      "1557\n",
      "1558\n",
      "1559\n",
      "1560\n",
      "1561\n",
      "1562\n",
      "1563\n",
      "1564\n",
      "1565\n",
      "1566\n",
      "1567\n",
      "1568\n",
      "1569\n",
      "1570\n",
      "1571\n",
      "1572\n",
      "1573\n",
      "1574\n",
      "1575\n",
      "1576\n",
      "1577\n",
      "1578\n",
      "1579\n",
      "1580\n",
      "1581\n",
      "1582\n",
      "1583\n",
      "1584\n",
      "1585\n",
      "1586\n",
      "1587\n",
      "1588\n",
      "1589\n",
      "1590\n",
      "1591\n",
      "1592\n",
      "1593\n",
      "1594\n",
      "1595\n",
      "1596\n",
      "1597\n",
      "1598\n",
      "1599\n",
      "1600\n",
      "1601\n",
      "1602\n",
      "1603\n",
      "1604\n",
      "1605\n",
      "1606\n",
      "1607\n",
      "1608\n",
      "1609\n",
      "1610\n",
      "1611\n",
      "1612\n",
      "1613\n",
      "1614\n",
      "1615\n",
      "1616\n",
      "1617\n",
      "1618\n",
      "1619\n",
      "1620\n",
      "1621\n",
      "1622\n",
      "1623\n",
      "1624\n",
      "1625\n",
      "1626\n",
      "1627\n",
      "1628\n",
      "1629\n",
      "1630\n",
      "1631\n",
      "1632\n",
      "1633\n",
      "1634\n",
      "1635\n",
      "1636\n",
      "1637\n",
      "1638\n",
      "1639\n",
      "1640\n",
      "1641\n",
      "1642\n",
      "1643\n",
      "1644\n",
      "1645\n",
      "1646\n",
      "1647\n",
      "1648\n",
      "1649\n",
      "1650\n",
      "1651\n",
      "1652\n",
      "1653\n",
      "1654\n",
      "1655\n",
      "1656\n",
      "1657\n",
      "1658\n",
      "1659\n",
      "1660\n",
      "1661\n",
      "1662\n",
      "1663\n",
      "1664\n",
      "1665\n",
      "1666\n",
      "1667\n",
      "1668\n",
      "1669\n",
      "1670\n",
      "1671\n",
      "1672\n",
      "1673\n",
      "1674\n",
      "1675\n",
      "1676\n",
      "1677\n",
      "1678\n",
      "1679\n",
      "1680\n",
      "1681\n",
      "1682\n",
      "1683\n",
      "1684\n",
      "1685\n",
      "1686\n",
      "1687\n",
      "1688\n",
      "1689\n",
      "1690\n",
      "1691\n",
      "1692\n",
      "1693\n",
      "1694\n",
      "1695\n",
      "1696\n",
      "1697\n",
      "1698\n",
      "1699\n",
      "1700\n",
      "1701\n",
      "1702\n",
      "1703\n",
      "1704\n",
      "1705\n",
      "1706\n",
      "1707\n",
      "1708\n",
      "1709\n",
      "1710\n",
      "1711\n",
      "1712\n",
      "1713\n",
      "1714\n",
      "1715\n",
      "1716\n",
      "1717\n",
      "1718\n",
      "1719\n",
      "1720\n",
      "1721\n",
      "1722\n",
      "1723\n",
      "1724\n",
      "1725\n",
      "1726\n",
      "1727\n",
      "1728\n",
      "1729\n",
      "1730\n",
      "1731\n",
      "1732\n",
      "1733\n",
      "1734\n",
      "1735\n",
      "1736\n",
      "1737\n",
      "1738\n",
      "1739\n",
      "1740\n",
      "1741\n",
      "1742\n",
      "1743\n",
      "1744\n",
      "1745\n",
      "1746\n",
      "1747\n",
      "1748\n",
      "1749\n",
      "1750\n",
      "1751\n",
      "1752\n",
      "1753\n",
      "1754\n",
      "1755\n",
      "1756\n",
      "1757\n",
      "1758\n",
      "1759\n",
      "1760\n",
      "1761\n",
      "1762\n",
      "1763\n",
      "1764\n",
      "1765\n",
      "1766\n",
      "1767\n",
      "1768\n",
      "1769\n",
      "1770\n",
      "1771\n",
      "1772\n",
      "1773\n",
      "1774\n",
      "1775\n",
      "1776\n",
      "1777\n",
      "1778\n",
      "1779\n",
      "1780\n",
      "1781\n",
      "1782\n",
      "1783\n",
      "1784\n",
      "1785\n",
      "1786\n",
      "1787\n",
      "1788\n",
      "1789\n",
      "1790\n",
      "1791\n",
      "1792\n",
      "1793\n",
      "1794\n",
      "1795\n",
      "1796\n",
      "1797\n",
      "1798\n",
      "1799\n",
      "1800\n",
      "1801\n",
      "1802\n",
      "1803\n",
      "1804\n",
      "1805\n",
      "1806\n",
      "1807\n",
      "1808\n",
      "1809\n",
      "1810\n",
      "1811\n",
      "1812\n",
      "1813\n",
      "1814\n",
      "1815\n",
      "1816\n",
      "1817\n",
      "1818\n",
      "1819\n",
      "1820\n",
      "1821\n",
      "1822\n",
      "1823\n",
      "1824\n",
      "1825\n",
      "1826\n",
      "1827\n",
      "1828\n",
      "1829\n",
      "1830\n",
      "1831\n",
      "1832\n",
      "1833\n",
      "1834\n",
      "1835\n",
      "1836\n",
      "1837\n",
      "1838\n",
      "1839\n",
      "1840\n",
      "1841\n",
      "1842\n",
      "1843\n",
      "1844\n",
      "1845\n",
      "1846\n",
      "1847\n",
      "1848\n",
      "1849\n",
      "1850\n",
      "1851\n",
      "1852\n",
      "1853\n",
      "1854\n",
      "1855\n",
      "1856\n",
      "1857\n",
      "1858\n",
      "1859\n",
      "1860\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1861\n",
      "1862\n",
      "1863\n",
      "1864\n",
      "1865\n",
      "1866\n",
      "1867\n",
      "1868\n",
      "1869\n",
      "1870\n",
      "1871\n",
      "1872\n",
      "1873\n",
      "1874\n",
      "1875\n",
      "1876\n",
      "1877\n",
      "1878\n",
      "1879\n",
      "1880\n",
      "1881\n",
      "1882\n",
      "1883\n",
      "1884\n",
      "1885\n",
      "1886\n",
      "1887\n",
      "1888\n",
      "1889\n",
      "1890\n",
      "1891\n",
      "1892\n",
      "1893\n",
      "1894\n",
      "1895\n",
      "1896\n",
      "1897\n",
      "1898\n",
      "1899\n",
      "1900\n",
      "1901\n",
      "1902\n",
      "1903\n",
      "1904\n",
      "1905\n",
      "1906\n",
      "1907\n",
      "1908\n",
      "1909\n",
      "1910\n",
      "1911\n",
      "1912\n",
      "1913\n",
      "1914\n",
      "1915\n",
      "1916\n",
      "1917\n",
      "1918\n",
      "1919\n",
      "1920\n",
      "1921\n",
      "1922\n",
      "1923\n",
      "1924\n",
      "1925\n",
      "1926\n",
      "1927\n",
      "1928\n",
      "1929\n",
      "1930\n",
      "1931\n",
      "1932\n",
      "1933\n",
      "1934\n",
      "1935\n",
      "1936\n",
      "1937\n",
      "1938\n",
      "1939\n",
      "1940\n",
      "1941\n",
      "1942\n",
      "1943\n",
      "1944\n",
      "1945\n",
      "1946\n",
      "1947\n",
      "1948\n",
      "1949\n",
      "1950\n",
      "1951\n",
      "1952\n",
      "1953\n",
      "1954\n",
      "1955\n",
      "1956\n",
      "1957\n",
      "1958\n",
      "1959\n",
      "1960\n",
      "1961\n",
      "1962\n",
      "1963\n",
      "1964\n",
      "1965\n",
      "1966\n",
      "1967\n",
      "1968\n",
      "1969\n",
      "1970\n",
      "1971\n",
      "1972\n",
      "1973\n",
      "1974\n",
      "1975\n",
      "1976\n",
      "1977\n",
      "1978\n",
      "1979\n",
      "1980\n",
      "1981\n",
      "1982\n",
      "1983\n",
      "1984\n",
      "1985\n",
      "1986\n",
      "1987\n",
      "1988\n",
      "1989\n",
      "1990\n",
      "1991\n",
      "1992\n",
      "1993\n",
      "1994\n",
      "1995\n",
      "1996\n",
      "1997\n",
      "1998\n",
      "1999\n"
     ]
    }
   ],
   "source": [
    "bt = dict()\n",
    "low = {2017: 1, 2018: 1, 2019: 1, 2020: 1}\n",
    "high = {2017: 10, 2018: 10, 2019: 10, 2020: 8}\n",
    "for year in range(2017, 2021):\n",
    "    bt[year] = anova_with_lm(data[year], 3, low[year], high[year], iters=2000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.82"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "round(np.percentile(bt[2017], [2.5, 50, 97.5])[1], 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAicAAAGXCAYAAABocvA1AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjMsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+AADFEAAAgAElEQVR4nO3dd5hcZdnH8e+9LZst6YWQngBJqIEkSFGKKFheVLDSktBE0VdRsGGLKL5YUBGkl0BAEaQoSJWmAsEkECmhphMgvWyS3ezuzP3+cc4mk8m2mT2zc2b397muvWbnzHPOuXeYK/PjOc95HnN3REREROKiKN8FiIiIiKRSOBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWCmocGJm5WY208xmm9lcMzu2hXalZvZLM/u3mb1kZr8zs+LOrldEREQyV1DhBJgBmLsfApwM3G5mg5tp9z3gIOBIYDJwOHB+ZxUpIiIi2SuYcGJmRcBZwA0A7v4G8AJwajPNpwI3u3vC3bcBtwBnd1atIiIikr2CCSfAGKA/8FrKtgUEPSPphgJrUp6vBPYws6rclSciIiJRKKRw0nT5ZkPKto3AoGbavk0QUJrsFj72yUFdIiIiEqGSfBcQAWtm20zgi2b2R4K/cWq4vS6bE9TU1GgBIhERkQhVV1c39/0NFFY4WRU+9kn5vXfK76kuAYqBR4HNBGFlPLA2mxNXV1dns5uIiIhkoZAu6ywE1gHjUrbtDcxJbxgOhL3I3Q939+MILv884VqCWUREJPYKJpy4exK4DjgDwMz2BCYCt5nZBDN7rGkuEzP7ZtMcKGbWC/ga8H/5qVxEREQyUUiXdSCY5+RqM5tNUPtJ7v6emY0iuGxTCiQIBsT+1szWEQSwi939mbxULCIiIhkxXeloF71JIiIi0WpxQGzBXNYRERGR7kHhRERERGJF4URERERiReFEREREYkXhRERERGJF4URERERiReFEREREYkXhRERERGJF4URERERiReFEREREYkXhRERERGJF4URERERiReFEREREYkXhRERERGJF4URERERiReFEREREYkXhRERERGJF4URERERiReFEREREYkXhRERERGJF4URERERiReFEREREYkXhRERERGJF4URERERiReFEREREYkXhRERERGJF4URE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sk5r85z8gOBL+dcEIaUIOAz4CsECgN8GhgHrgSuAy9x9XUQFi4iISDfVWs/JKuD77n5d2vYvApcCpQRznvza3TfnutA8U8+JiIhItDK/W8fMEsBu7r46bftAYCVwsrvfHmWVMaZwIiIiEq3swklLtwSHwaXS3euiqS/2FE5ERESiFf2txC0FkzC4iIiIiGQlsnlOUrS2anHHDmxWbmYzzWy2mc01s2PbaF9qZm+Z2Yxc1SQiIiLRau1uHWutF6SV13J5CWQGwaWoQ8xsL2C2mU1w95UttP8iMDCH9YiIiEjE2uo5sSx+csLMioCzgBsA3P0N4AXg1BbaVwGfA+7LVU0iIiISvdbCibt7UaY/Oax1DNAfeC1l2wJgcgvtzwcuBxpzWJOIiIhErLXLOsuyPGa2+7VlcPi4IWXbRmDv9Ibh7c5HuPtPzOx/Onrimpqajh5CREREUlRXV7f4Wos9He4+OpuTZbtfBzR3KemHwMWdXIeIiIhEoLWek7hZFT72Sfm9d8rvAJjZaGC0uz8e1YlbS3ciIiISrUIKJwuBdcA4dgSSvYEH0todBexuZk+Gz8cDdWZ2FHC6uy/OeaUiIiKStRZniI0jM7sEGOzup5vZnsBsYB+gL8Hig8e6eyJtn5nAEnef0YFTF86bJCIiUhiyWpU4jmYAV5vZbILaT3L398xsFEEPSSmQADCzMuARdvSc7O/uJ+ajaBEREWm/guo5ySO9SSIiItGKfm0dERERkVxQOBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYUTgRERGRWFE4ERERkVhROBEREZFYKahwYmblZjbTzGab2VwzO7aFdsea2QNm9oiZvWhm15hZj86u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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# reproducibility level over year\n",
    "# reproducibility_y = [0.82, 0.78, 0.79, 0.57]\n",
    "reproducibility_y = [bt[2017], bt[2018], bt[2019], bt[2020]]\n",
    "\n",
    "# year\n",
    "year_x = list(map(str, range(2017, 2021)))\n",
    "\n",
    "# Seaborn plot\n",
    "sns.set_context('talk')\n",
    "\n",
    "# create dataframe for plotting\n",
    "plot_df = pd.DataFrame(dict({'Year': year_x,\n",
    "                             'Reproducibility': reproducibility_y\n",
    "                            }))\n",
    "\n",
    "# initiailize figure and axis\n",
    "fig, ax = plt.subplots(figsize=(8, 6))\n",
    "tidy = plot_df.melt(id_vars='Year').rename(columns=str.title)\n",
    "tidy.columns = ['Year', 'Type', 'Rate']\n",
    "lineplot = sns.lineplot(x='Year', y='Rate', hue='Type', data=tidy, ax=ax)\n",
    "\n",
    "# Axis styling.\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "ax.spines['left'].set_visible(False)\n",
    "ax.spines['bottom'].set_color('#DDDDDD')\n",
    "ax.tick_params(bottom=False, left=False)\n",
    "ax.set_axisbelow(True)\n",
    "ax.yaxis.grid(True, color='#EEEEEE')\n",
    "ax.xaxis.grid(False)\n",
    "ax.set(ylim=(0.3, 0.9))\n",
    "\n",
    "for tick in ax.xaxis.get_major_ticks():\n",
    "    tick.label.set_fontsize(12) \n",
    "for tick in ax.yaxis.get_major_ticks():\n",
    "    tick.label.set_fontsize(12)  \n",
    "    \n",
    "ax.get_legend().set_visible(False)\n",
    "\n",
    "\n",
    "# Axis labeling\n",
    "ax.set_xlabel('Year', labelpad=15, fontsize=20)\n",
    "ax.set_ylabel('Reproducibility Level', labelpad=15, fontsize=20)\n",
    "#ax.set_title('Reproducibility Level, Krippendorff Alpha Reliability & Spearman Correlation for Citation', pad=15)\n",
    "\n",
    "fig.tight_layout()\n",
    "\n",
    "plt.savefig(\"anova_reproducibility.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "std_between, std_within: 2.33340641658784 , 1.0307258263293844\n",
      "std_between, std_within: 2.1080389619303372 , 1.1947186434561534\n",
      "std_between, std_within: 2.10380186756451 , 1.1036187598032512\n",
      "std_between, std_within: 2.959577800103693 , 1.7209573403504703\n"
     ]
    }
   ],
   "source": [
    "for year in range(2017, 2021):\n",
    "    d = get_ratings_lst(df[df['year'] == year])\n",
    "    std_between = get_variance_between(d) ** 0.5\n",
    "    std_within = get_variance_within(d) ** 0.5\n",
    "    print(\"std_between, std_within:\", std_between, \",\", std_within)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
